- dumps是將dict轉(zhuǎn)化成str格式,loads是將str轉(zhuǎn)化成dict格式。
- dump和load也是類(lèi)似的功能,只是與文件操作結(jié)合起來(lái)了。
代碼實(shí)例:
import json
dic_a = {'name': 'wang', 'age': 29}
str_b = json.dumps(dic_a)
print(type(str_b),str_b) #<class 'str'> {"name": "wang", "age": 29}
dic_c = json.loads(str_b)
print(type(dic_c),dic_c) #<class 'dict'> {'name': 'wang', 'age': 29}
然后再看dump和dumps的區(qū)別,見(jiàn)代碼:
import json
dic_a = {'name': 'wang', 'age': 29}
str_b = json.dumps(dic_a)
print(type(str_b),str_b) #<class 'str'> {"name": "wang", "age": 29}
#c = json.dump(dic_a)
# TypeError: dump() missing 1 required positional argument: 'fp'
c = json.dump(dic_a)
dump需要一個(gè)類(lèi)似于文件指針的參數(shù)(并不是真的指針,可稱(chēng)之為類(lèi)文件對(duì)象),可以與文件操作結(jié)合,也就是說(shuō)可以將dict轉(zhuǎn)成str然后存入文件中;而dumps直接給的是str,也就是將字典轉(zhuǎn)成str。
例子見(jiàn)代碼(注意文件操作的一些小細(xì)節(jié)):
import json
dic_a = {'name': 'wang', 'age': 29}
str_b = json.dumps(dic_a)
print(type(str_b),str_b) #<class 'str'> {"name": "wang", "age": 29}
#c = json.dump(dic_a)
# TypeError: dump() missing 1 required positional argument: 'fp'
c = json.dump(dic_a,open('str_b.txt','w'))
注:實(shí)際中dump用的較少。