Python Language
JSON मॉड्यूल
खोज…
टिप्पणियों
संस्करण-विशिष्ट कार्यक्षमता सहित पूर्ण प्रलेखन के लिए, कृपया आधिकारिक दस्तावेज़ देखें ।
प्रकार
चूक
json मॉड्यूल डिफ़ॉल्ट रूप से निम्न प्रकार के एन्कोडिंग और डिकोडिंग को संभालेगा:
डी-क्रमांकन प्रकार:
| JSON | अजगर |
|---|---|
| वस्तु | dict |
| सरणी | सूची |
| तार | str |
| संख्या (int) | पूर्णांक |
| संख्या (वास्तविक) | नाव |
| सही गलत | सही गलत |
| शून्य | कोई नहीं |
json मॉड्यूल NaN , Infinity और -Infinity को भी उनके संगत फ्लोट मान के रूप में -Infinity , जो JSON कल्पना के बाहर है।
क्रमांकन प्रकार:
| अजगर | JSON |
|---|---|
| dict | वस्तु |
| सूची, टपल | सरणी |
| str | तार |
| int, फ्लोट, (int / float) -मेंडेड एनम | संख्या |
| सच | सच |
| असत्य | असत्य |
| कोई नहीं | शून्य |
NaN , Infinity , और -Infinity की एन्कोडिंग को -Infinity आपको allow_nan=False साथ एन्कोड करना होगा। यदि आप इन मानों को एनकोड करने का प्रयास करते हैं तो यह एक ValueError बढ़ाएगा।
कस्टम (डी-) क्रमबद्धता
विभिन्न हुक हैं जो आपको डेटा को संभालने की अनुमति देते हैं जिन्हें अलग-अलग प्रतिनिधित्व करने की आवश्यकता होती है। functools.partial उपयोग आपको सुविधा के लिए इन कार्यों के लिए प्रासंगिक मापदंडों को आंशिक रूप से लागू करने की अनुमति देता है।
क्रमबद्धता:
आप एक ऐसा कार्य प्रदान कर सकते हैं जो वस्तुओं पर काम करता है इससे पहले कि वे क्रमबद्ध हों जैसे:
# my_json module
import json
from functools import partial
def serialise_object(obj):
# Do something to produce json-serialisable data
return dict_obj
dump = partial(json.dump, default=serialise_object)
dumps = partial(json.dumps, default=serialise_object)
डी-क्रमबद्धता:
विभिन्न प्रकार के हुक हैं जो कि json फ़ंक्शन द्वारा नियंत्रित किए जाते हैं, जैसे कि object_hook और parse_float। अजगर के अपने संस्करण के लिए एक विस्तृत सूची के लिए, यहां देखें ।
# my_json module
import json
from functools import partial
def deserialise_object(dict_obj):
# Do something custom
return obj
def deserialise_float(str_obj):
# Do something custom
return obj
load = partial(json.load, object_hook=deserialise_object, parse_float=deserialise_float)
loads = partial(json.loads, object_hook=deserialise_object, parse_float=deserialise_float)
आगे की प्रथा (डी) क्रमबद्धता:
json मॉड्यूल भी json.JSONEncoder और json.JSONDecoder विस्तार / प्रतिस्थापन के लिए विविध प्रकारों को संभालने की अनुमति देता है। ऊपर दर्ज़ किए गए हुक को एक समान रूप से नामित विधि बनाकर डिफॉल्ट के रूप में जोड़ा जा सकता है। इन का उपयोग करने के लिए बस संबंधित फ़ंक्शन के लिए cls पैरामीटर के रूप में कक्षा पास करें। functools.partial उपयोग आपको सुविधा के लिए इन कार्यों के लिए functools.partial पैरामीटर को आंशिक रूप से लागू करने की अनुमति देता है, जैसे
# my_json module
import json
from functools import partial
class MyEncoder(json.JSONEncoder):
# Do something custom
class MyDecoder(json.JSONDecoder):
# Do something custom
dump = partial(json.dump, cls=MyEncoder)
dumps = partial(json.dumps, cls=MyEncoder)
load = partial(json.load, cls=MyDecoder)
loads = partial(json.loads, cls=MyDecoder)
पाइथन से JSON बनाना तानाशाह
import json
d = {
'foo': 'bar',
'alice': 1,
'wonderland': [1, 2, 3]
}
json.dumps(d)
उपरोक्त स्निपेट निम्नलिखित को वापस करेगा:
'{"wonderland": [1, 2, 3], "foo": "bar", "alice": 1}'
JSON से पाइथन को तानाशाह बनाना
import json
s = '{"wonderland": [1, 2, 3], "foo": "bar", "alice": 1}'
json.loads(s)
उपरोक्त स्निपेट निम्नलिखित को वापस करेगा:
{u'alice': 1, u'foo': u'bar', u'wonderland': [1, 2, 3]}
किसी फ़ाइल में डेटा संग्रहीत करना
निम्न स्निपेट JSON में d में संग्रहीत डेटा को एन्कोड करता है और इसे एक फ़ाइल में संग्रहीत करता है ( filename का वास्तविक नाम के साथ filename बदलें)।
import json
d = {
'foo': 'bar',
'alice': 1,
'wonderland': [1, 2, 3]
}
with open(filename, 'w') as f:
json.dump(d, f)
किसी फ़ाइल से डेटा पुनर्प्राप्त करना
निम्न स्निपेट एक JSON एन्कोडेड फ़ाइल ( filename का वास्तविक नाम के साथ filename बदलें) को खोलता है और फ़ाइल में संग्रहीत ऑब्जेक्ट को वापस करता है।
import json
with open(filename, 'r') as f:
d = json.load(f)
`लोड` बनाम` लोड`, `डंप` बनाम` डिप्स`
json मॉड्यूल में यूनिकोड स्ट्रिंग्स से पढ़ने और लिखने और फ़ाइलों से और पढ़ने और लिखने दोनों के लिए फ़ंक्शंस होते हैं। ये फ़ंक्शन नाम में एक अनुगामी s द्वारा विभेदित हैं। इन उदाहरणों में हम एक स्ट्रिंग ऑब्जेक्ट का उपयोग करते हैं, लेकिन वही फ़ंक्शन किसी भी फ़ाइल जैसी ऑब्जेक्ट के लिए लागू होगा।
यहां हम स्ट्रिंग-आधारित कार्यों का उपयोग करते हैं:
import json
data = {u"foo": u"bar", u"baz": []}
json_string = json.dumps(data)
# u'{"foo": "bar", "baz": []}'
json.loads(json_string)
# {u"foo": u"bar", u"baz": []}
और यहां हम फ़ाइल-आधारित फ़ंक्शन का उपयोग करते हैं:
import json
from io import StringIO
json_file = StringIO()
data = {u"foo": u"bar", u"baz": []}
json.dump(data, json_file)
json_file.seek(0) # Seek back to the start of the file before reading
json_file_content = json_file.read()
# u'{"foo": "bar", "baz": []}'
json_file.seek(0) # Seek back to the start of the file before reading
json.load(json_file)
# {u"foo": u"bar", u"baz": []}
जैसा कि आप देख सकते हैं कि मुख्य अंतर यह है कि जब जसन डेटा डंप करते हैं तो आपको फंक्शन को फाइल हैंडल को पास करना होगा, जैसा कि रिटर्न वैल्यू पर कब्जा करने के लिए है। यह भी ध्यान देने योग्य है कि डेटा भ्रष्टाचार से बचने के लिए, आपको पढ़ने या लिखने से पहले फ़ाइल की शुरुआत करनी चाहिए। फ़ाइल खोलते समय कर्सर को 0 स्थिति में रखा जाता है, इसलिए नीचे भी काम किया जाएगा:
import json
json_file_path = './data.json'
data = {u"foo": u"bar", u"baz": []}
with open(json_file_path, 'w') as json_file:
json.dump(data, json_file)
with open(json_file_path) as json_file:
json_file_content = json_file.read()
# u'{"foo": "bar", "baz": []}'
with open(json_file_path) as json_file:
json.load(json_file)
# {u"foo": u"bar", u"baz": []}
Json डेटा से निपटने के दोनों तरीके होने से आप मुहावरेदार और कुशलता से उन स्वरूपों के साथ काम कर सकते हैं, जो json पर निर्मित होते हैं, जैसे pyspark का json-per-line:
# loading from a file
data = [json.loads(line) for line in open(file_path).splitlines()]
# dumping to a file
with open(file_path, 'w') as json_file:
for item in data:
json.dump(item, json_file)
json_file.write('\n')
JSON आउटपुट को प्रिंट करने के लिए कमांड लाइन से `json.tool` कॉल करना
कुछ JSON फ़ाइल "foo.json" को देखते हुए जैसे:
{"foo": {"bar": {"baz": 1}}}
हम कमांड लाइन से सीधे मॉड्यूल को कॉल कर सकते हैं (फ़ाइलनाम को एक तर्क के रूप में पारित कर सकते हैं) इसे सुंदर प्रिंट करें:
$ python -m json.tool foo.json
{
"foo": {
"bar": {
"baz": 1
}
}
}
मॉड्यूल STDOUT से भी इनपुट लेगा, इसलिए (बाश में) हम समान रूप से कर सकते हैं:
$ cat foo.json | python -m json.tool
JSON आउटपुट स्वरूपण
मान लें कि हमारे पास निम्नलिखित डेटा हैं:
>>> data = {"cats": [{"name": "Tubbs", "color": "white"}, {"name": "Pepper", "color": "black"}]}
बस इसे डंपिंग के रूप में JSON यहाँ कुछ विशेष नहीं करता है:
>>> print(json.dumps(data))
{"cats": [{"name": "Tubbs", "color": "white"}, {"name": "Pepper", "color": "black"}]}
Prettier आउटपुट पाने के लिए इंडेंटेशन सेट करना
यदि हम सुंदर मुद्रण चाहते हैं, तो हम एक indent आकार सेट कर सकते हैं:
>>> print(json.dumps(data, indent=2))
{
"cats": [
{
"name": "Tubbs",
"color": "white"
},
{
"name": "Pepper",
"color": "black"
}
]
}
लगातार आउटपुट प्राप्त करने के लिए वर्णमाला की तरह छँटाई करना
डिफ़ॉल्ट रूप से आउटपुट में कुंजियों का क्रम अपरिभाषित होता है। हम उन्हें वर्णमाला क्रम में प्राप्त कर सकते हैं यह सुनिश्चित करने के लिए कि हम हमेशा एक ही आउटपुट प्राप्त करें:
>>> print(json.dumps(data, sort_keys=True))
{"cats": [{"color": "white", "name": "Tubbs"}, {"color": "black", "name": "Pepper"}]}
कॉम्पैक्ट आउटपुट पाने के लिए व्हाट्सएप से छुटकारा
हम अनावश्यक रिक्त स्थान से छुटकारा पाना चाहते हैं, जो कि डिफॉल्ट से अलग विभाजक तारों को सेट करके किया जाता है ', ' और ': ' :
>>>print(json.dumps(data, separators=(',', ':')))
{"cats":[{"name":"Tubbs","color":"white"},{"name":"Pepper","color":"black"}]}
JSON कस्टम ऑब्जेक्ट एन्कोडिंग
यदि हम निम्नलिखित प्रयास करें:
import json
from datetime import datetime
data = {'datetime': datetime(2016, 9, 26, 4, 44, 0)}
print(json.dumps(data))
हमें TypeError: datetime.datetime(2016, 9, 26, 4, 44) is not JSON serializable एरर कहते हुए एक त्रुटि मिलती है TypeError: datetime.datetime(2016, 9, 26, 4, 44) is not JSON serializable ।
डेटाटाइम ऑब्जेक्ट को ठीक से अनुक्रमित करने में सक्षम होने के लिए, हमें इसे परिवर्तित करने के लिए कस्टम कोड लिखने की आवश्यकता है:
class DatetimeJSONEncoder(json.JSONEncoder):
def default(self, obj):
try:
return obj.isoformat()
except AttributeError:
# obj has no isoformat method; let the builtin JSON encoder handle it
return super(DatetimeJSONEncoder, self).default(obj)
और फिर json.dumps बजाय इस एनकोडर वर्ग का उपयोग करें:
encoder = DatetimeJSONEncoder()
print(encoder.encode(data))
# prints {"datetime": "2016-09-26T04:44:00"}