JSON

अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है मॉड्यूल json, JSON से जुड़े फ़ंक्शन का एक Starlark मॉड्यूल है.

सदस्य

डिकोड करें

unknown json.decode(x)

डिकोड करने वाले फ़ंक्शन में, पोज़िशनल पैरामीटर के तौर पर एक JSON स्ट्रिंग होती है. यह Starlark की उस वैल्यू को दिखाता है जिसे स्ट्रिंग दिखाता है.
  • 'शून्य', 'सही', और 'गलत' को कोई नहीं, सही, और गलत के तौर पर पार्स किया जाता है.
  • अगर संख्याओं में दशमलव बिंदु या घातांक है, तो संख्याओं को पूर्णांक या फ़्लोट के रूप में पार्स किया जाता है. हालांकि, JSON में नॉन-फ़ाइनाइट वैल्यू के लिए कोई सिंटैक्स नहीं है, लेकिन बहुत बड़ी वैल्यू को इनफ़िनिटी के तौर पर डिकोड किया जा सकता है.
  • JSON ऑब्जेक्ट को नए बिना फ़्रीज़ किए गए Starlark डिक्शनरी के तौर पर पार्स किया गया है. अगर ऑब्जेक्ट में एक ही कुंजी स्ट्रिंग एक से ज़्यादा बार आती है, तो कुंजी की आखिरी वैल्यू को सेव रखा जाता है.
  • JSON कलेक्शन को ऐसी नई Starlark सूची के तौर पर पार्स किया गया है जिसे फ़्रीज़ नहीं किया गया है.
अगर x एक मान्य JSON एन्कोडिंग नहीं है, तो डिकोड नहीं किया जा सकता.

पैरामीटर

पैरामीटर ब्यौरा
x ज़रूरी है

कोड में बदलें

string json.encode(x)

एन्कोड फ़ंक्शन एक ज़रूरी पोज़िशनल आर्ग्युमेंट को स्वीकार करता है, जिसे केस के हिसाब से, JSON में बदला जाता है:

  • कोई नहीं, सही, और गलत को क्रम से 'शून्य', 'सही', और 'गलत' में बदला जाता है.
  • पूर्णांक को दशमलव पूर्णांक के तौर पर एन्कोड किया जाता है. इससे कोई फ़र्क़ नहीं पड़ता कि पूर्णांक कितना बड़ा है. ऐसा हो सकता है कि कुछ डिकोडर, बहुत बड़े पूर्णांकों को डिकोड न कर पाएं.
  • फ़्लोट को दशमलव बिंदु या घातांक या दोनों का इस्तेमाल करके एन्कोड किया जाता है. भले ही, संख्या वाली वैल्यू एक पूर्णांक हो. नॉन-फ़ाइनाइट फ़्लोटिंग-पॉइंट वैल्यू को कोड में बदलने में गड़बड़ी हुई.
  • स्ट्रिंग की वैल्यू को JSON स्ट्रिंग की लिटरल वैल्यू के तौर पर एन्कोड किया जाता है. यह वैल्यू दिखाता है. जुड़े हुए हर सरोगेट को U+FFFD से बदल दिया जाता है.
  • डिक्शनरी को कुंजी के क्रम में, JSON ऑब्जेक्ट के तौर पर कोड में बदला जाता है. अगर कोई कुंजी कोई स्ट्रिंग नहीं है, तो यह एक गड़बड़ी है.
  • सूची या टपल को JSON अरे के तौर पर एन्कोड किया जाता है.
  • स्ट्रक्चर जैसी वैल्यू को फ़ील्ड के नाम के क्रम में, JSON ऑब्जेक्ट के तौर पर एन्कोड किया जाता है.
ऐप्लिकेशन के ज़रिए तय किया गया कोई टाइप, अपनी JSON एन्कोडिंग को तय कर सकता है. किसी अन्य वैल्यू को कोड में बदलने में गड़बड़ी होती है.

पैरामीटर

पैरामीटर ब्यौरा
x ज़रूरी है

encode_indent

string json.encode_indent(x, *, prefix='', indent='\t')

encode_indent फ़ंक्शन json.indent(json.encode(x), ...) के बराबर है. फ़ॉर्मैटिंग पैरामीटर की जानकारी के लिए, indent पर जाएं.

पैरामीटर

पैरामीटर ब्यौरा
x ज़रूरी है
prefix डिफ़ॉल्ट = ''
indent डिफ़ॉल्ट = '\t'

इंडेंट

string json.indent(s, *, prefix='', indent='\t')

इंडेंट फ़ंक्शन, JSON कोड में बदली गई मान्य स्ट्रिंग का इंडेंट किया गया फ़ॉर्म दिखाता है. हर अरे एलिमेंट या ऑब्जेक्ट फ़ील्ड एक नई लाइन पर दिखता है. इसकी शुरुआत प्रीफ़िक्स स्ट्रिंग से होती है. इसके बाद, इंडेंट स्ट्रिंग की एक या उससे ज़्यादा कॉपी, नेस्ट की गई डेप्थ के हिसाब से दिखती हैं. फ़ंक्शन एक ज़रूरी पोज़िशनल पैरामीटर, JSON स्ट्रिंग, और दो वैकल्पिक केवल-कीवर्ड स्ट्रिंग पैरामीटर, प्रीफ़िक्स और इंडेंट हैं, जो हर नई लाइन के प्रीफ़िक्स और इंडेंट की इकाई को तय करते हैं. अगर इनपुट मान्य नहीं है, तो हो सकता है कि फ़ंक्शन काम न करे या अमान्य आउटपुट दिखाए.

पैरामीटर

पैरामीटर ब्यौरा
s ज़रूरी है
prefix डिफ़ॉल्ट = ''
indent डिफ़ॉल्ट = '\t'