您好,登錄后才能下訂單哦!
這篇文章主要介紹“python的json模塊怎么使用”的相關(guān)知識(shí),小編通過(guò)實(shí)際案例向大家展示操作過(guò)程,操作方法簡(jiǎn)單快捷,實(shí)用性強(qiáng),希望這篇“python的json模塊怎么使用”文章能幫助大家解決問(wèn)題。
推薦使用參考網(wǎng)站: json
在python中,json模塊可以實(shí)現(xiàn)json數(shù)據(jù)的序列化和反序列化
序列化:將可存放在內(nèi)存中的python 對(duì)象轉(zhuǎn)換成可物理存儲(chǔ)和傳遞的形式
實(shí)現(xiàn)方法:load() loads()
反序列化:將可物理存儲(chǔ)和傳遞的json數(shù)據(jù)形式轉(zhuǎn)換為在內(nèi)存中表示的python對(duì)象
實(shí)現(xiàn)方法:dump() dumps()
def dump(obj, fp, *, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw):
1.把python對(duì)象obj轉(zhuǎn)換成物理表現(xiàn)形式fp流。其中fp的.write()可以支持寫入類文件中
2.如果skipkeys是true,那么在處理json對(duì)象的時(shí)候,僅支持 (str, int, float, bool, None) 這些基本類型的key,如果有非基本類型,就會(huì)拋出TypeError異常;如果值為false,那么對(duì)于非基本類型,則會(huì)拋出TypeError;默認(rèn)值為false
3.如果ensure_ascii是true,那么obj中字符在寫入fp的時(shí)候,非ascii字符會(huì)被進(jìn)行轉(zhuǎn)義;如果值為false,那么對(duì)于這些非ascii字符不會(huì)進(jìn)行轉(zhuǎn)義,會(huì)原樣寫入;默認(rèn)值為true
4.如果check_circular是false,那么遇到container類型(list,dict,自定義編碼類型)的時(shí)候,不會(huì)循環(huán)引用檢查,一旦是循環(huán)引用,結(jié)果就是OverflowError;如果值為true,那么會(huì)對(duì)container類型進(jìn)行循環(huán)引用檢查,檢查失敗會(huì) raise ValueError(“Circular reference detected”);默認(rèn)值是true
5.如果allow_nan是false,嚴(yán)格遵守json的規(guī)范,對(duì)于序列化一些超出float范圍的值(nan, inf, -inf)的時(shí)候,會(huì)拋出ValueError;如果值為true,那么超過(guò)float范圍的值將會(huì)使用在JavaScript中的等效值(NaN, Infinity, -Infinity);默認(rèn)值為true
6.如果indent是一個(gè)non-negative (正)整數(shù),那么json中的數(shù)組元素和對(duì)象元素都將會(huì)使用indent單位縮進(jìn)格式來(lái)進(jìn)行輸出;值為0的時(shí)候,就只會(huì)插入一個(gè)換行符;值為None的時(shí)候,會(huì)輸出最緊湊的格式
7.separators的指定是以元組(item_separator, key_separator)的方式;如果indent=‘None’ 那么該選項(xiàng)的默認(rèn)值為(', ', ': '),否則該選項(xiàng)的默認(rèn)值為(',', ': ');如果想要緊湊的json表達(dá),那么應(yīng)該使用(',', ': ')來(lái)去除空格
8.default(obj)是一個(gè)函數(shù),主要是針對(duì)于那些無(wú)法被直接序列化的對(duì)象。該參數(shù)可以提供一個(gè)默認(rèn)的序列化版本,否則就會(huì)拋出一個(gè)TypeError。默認(rèn)是拋出TypeError
9.如果sort_keys是true,那么輸出的時(shí)候會(huì)根據(jù)key進(jìn)行排序,默認(rèn)值是false可以指定一個(gè)JSONEncoder的子類,來(lái)序列化其他的類型,可以通過(guò)cls或者是JSONEncoder參數(shù)來(lái)指定
def dumps(obj, *, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw):
4.把obj序列化成一個(gè)json格式的字符串,并返回該字符串支持的python內(nèi)置可進(jìn)行json序列化的類型有(str, int, float, bool, None,list,tuple,dict)如果無(wú)法序列化的類型,會(huì)拋出TypeError
2.其他參數(shù)同上解釋
def load(fp, *, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw):
1.把物理表現(xiàn)形式fp流(fp.read()的返回需要是一個(gè)json格式)反序列化成一個(gè)python對(duì)象
2.object_hook是一個(gè)可選的函數(shù),主要用來(lái)對(duì)直接反序列化之后的結(jié)果進(jìn)行二次加工;object_hook的參數(shù)只有一個(gè),是dict,該dict也是反序列化的直接結(jié)果;object_hook的返回值為load方法的返回值 ;這個(gè)功能一般是用來(lái)自定義解碼器,例如JSON-RPC
3.object_pairs_hook是一個(gè)可選的函數(shù),主要用來(lái)對(duì)直接反序列化之后的結(jié)果進(jìn)行二次加工;object_pairs_hook的參數(shù)只有一個(gè),是list(tuple),該list(tuple)也是反序列化的直接結(jié)果;object_pairs_hook的返回值為load方法的返回值 ;這個(gè)功能一般是用來(lái)自定義解碼器,例如JSON-RPC;在同時(shí)指定了object_hook和object_pairs_hook的時(shí)候,object_pairs_hook的優(yōu)先級(jí)高于object_hook
4.cls的關(guān)鍵字參數(shù),支持使用自定義的JSONDecoder的子類;如果不指定,默認(rèn)使用JSONDecoder
def loads(s, *, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw):
1.反序列化一個(gè)s(包含json文本的str,bytes,bytearray的實(shí)例對(duì)象)到一個(gè)python對(duì)象
2.object_hook 同上
3.object_pairs_hook同上
4.parse_float 如果定義了,那么會(huì)在對(duì)json字符串中的每一個(gè)float進(jìn)行解碼的時(shí)候調(diào)用;默認(rèn)情況下等價(jià)于 float(num_str);也可以使用其他的數(shù)據(jù)類型,如(e.g. decimal.Decimal)
5.parse_int 如果定義了,那么會(huì)在對(duì)json字符串中的每一個(gè)float進(jìn)行解碼的時(shí)候調(diào)用;默認(rèn)情況下,等價(jià)于 int(num_str);也可使用其他針對(duì)于json中的integer的datatype或者是parser
6.parse_constant 如果定義了,那么在碰到-Infinity, Infinity, NaN.這些的時(shí)候會(huì)被調(diào)用;如果遇到無(wú)效的json符號(hào),會(huì)拋出異常
import json if __name__ == '__main__': # 測(cè)試格式化非json格式數(shù)據(jù) print('-------------測(cè)試格式化非json格式數(shù)據(jù)----------------') a = json.dumps(2.0) print(a, type(a)) a = json.dumps(tuple()) print(a, type(a)) a = json.dumps([]) print(a, type(a)) # 測(cè)試格式化json格式數(shù)據(jù) print('-------------測(cè)試格式化json格式數(shù)據(jù)----------------') j = {'a': 1, 'b': 6} a = json.dumps(j) print(a, type(a)) # 測(cè)試skipkeys參數(shù) print('-------------測(cè)試skipkeys參數(shù)----------------') j = {'a': 1, tuple(): 6} a = json.dumps(j, skipkeys=True) print(a, type(a)) # 測(cè)試indent參數(shù) print('-------------測(cè)試indent默認(rèn)參數(shù)----------------') j = {'a': 1, 'b': 234} a = json.dumps(j) print(a, type(a)) print('-------------測(cè)試indent=0參數(shù)----------------') a = json.dumps(j, indent=0) print(a, type(a)) print('-------------測(cè)試indent=2參數(shù)----------------') a = json.dumps(j, indent=2) print(a, type(a)) print('-------------測(cè)試separators參數(shù)----------------') a = json.dumps(j, separators=('[', ']')) print(a, type(a))
import json if __name__ == '__main__': # 測(cè)試格式化非json格式數(shù)據(jù) fp = open('./json_dump_data', mode='w') print('-------------測(cè)試格式化非json格式數(shù)據(jù)----------------') a = json.dump(2.0, fp) fp.write('\n') a = json.dump(tuple(), fp) a = json.dump([], fp) fp.write('\n') # 測(cè)試格式化json格式數(shù)據(jù) j = {'a': 1, 'b': 6} a = json.dump(j, fp)
cat json_dump_data:
1和2中很多參數(shù)都是相同的,這里就不再詳述3.load()
import json if __name__ == '__main__': j = open('./json_data', mode='r') # 測(cè)試默認(rèn)參數(shù) a = json.load(j) print('-------------測(cè)試默認(rèn)參數(shù)----------------') print(a) # 測(cè)試object_hook參數(shù) j = open('./json_data', mode='r') a = json.load(j, object_hook=lambda x: x.get('b')) print('-------------測(cè)試object_hook參數(shù)----------------') print(a) # 測(cè)試object_pairs_hook參數(shù) j = open('./json_data', mode='r') loads = json.load(j, object_pairs_hook=lambda x: print(type(x), type(x[2]))) print('-------------測(cè)試object_pairs_hook參數(shù)----------------') print(loads) # 測(cè)試parse_constant參數(shù) j = open('./json_data', mode='r') loads = json.load(j, parse_constant=lambda x: 'not notification') print('-------------測(cè)試parse_constant參數(shù)----------------') print(loads) # 測(cè)試parse_int參數(shù) j = open('./json_data', mode='r') loads = json.load(j, parse_int=lambda x: 'cutomer int') print('-------------測(cè)試parse_int參數(shù)----------------') print(loads) # 測(cè)試parse_float參數(shù) j = open('./json_data', mode='r') loads = json.load(j, parse_float=lambda x: 'cutomer float') print('-------------測(cè)試parse_float參數(shù)----------------') print(loads)
注:
因?yàn)閘oad方法的底層是調(diào)用了fp.read(),所以每一次重新調(diào)用load的時(shí)候都需要重新打開(kāi)文件句柄。不然就會(huì)導(dǎo)致在第二次調(diào)用load方法的時(shí)候,就會(huì)因?yàn)閒p.read()返回的是none就導(dǎo)致異常
import json if __name__ == '__main__': j = '{"a":1,"b":2.0,"c":Infinity}' # 測(cè)試默認(rèn)參數(shù) a = json.loads(j) print('-------------測(cè)試默認(rèn)參數(shù)----------------') print(a) # 測(cè)試object_hook參數(shù) a = json.loads(j, object_hook=lambda x: x.get('b')) print('-------------測(cè)試object_hook參數(shù)----------------') print(a) # 測(cè)試object_pairs_hook參數(shù) loads = json.loads(j, object_pairs_hook=lambda x: print(type(x), type(x[2]))) print('-------------測(cè)試object_pairs_hook參數(shù)----------------') print(loads) # 測(cè)試parse_constant參數(shù) loads = json.loads(j, parse_constant=lambda x: 'not notification') print('-------------測(cè)試parse_constant參數(shù)----------------') print(loads) # 測(cè)試parse_int參數(shù) loads = json.loads(j, parse_int=lambda x: 'cutomer int') print('-------------測(cè)試parse_int參數(shù)----------------') print(loads) # 測(cè)試parse_float參數(shù) loads = json.loads(j, parse_float=lambda x: 'cutomer float') print('-------------測(cè)試parse_float參數(shù)----------------') print(loads)
關(guān)于“python的json模塊怎么使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。