https://blog.csdn.net/weixin_38842821/article/details/108359551
json庫的一些用法
方法 作用
json.dumps() 將python對象編碼成Json字符串
json.loads() 將Json字符串解碼成python對象
json.dump() 將python中的對象轉化成json儲存到文件中
json.load() 將文件中的json的格式轉化成python對象提取出來
json.dump()和json.dumps()的區別
json.dumps() 是把python對象轉換成json對象的一個過程,生成的是字符串。
json.dump() 是把python對象轉換成json對象生成一個fp的文件流,和文件相關。
import json
data = {
'name' : 'myname',
'age' : 100,
}
json_str = json.dumps(data)
json參數
json.dumps(obj, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, encoding="utf-8", default=None, sort_keys=False, **kw)
1
obj:轉化成json的對象。
sort_keys =True:是告訴編碼器按照字典排序(a到z)輸出。如果是字典類型的python對象,就把關鍵字按照字典排序。
indent:參數根據數據格式縮進顯示,讀起來更加清晰。
separators:是分隔符的意思,參數意思分別為不同dict項之間的分隔符和dict項內key和value之間的分隔符,把:和,后面的空格都除去了。
import json
x = {'name':'你猜','age':19,'city':'四川'}
#用dumps將python編碼成json字符串
y = json.dumps(x)
print(y)
i = json.dumps(x,separators=(',',':'))
print(i)
# 輸出結果
{"name": "\u4f60\u731c", "age": 19, "city": "\u56db\u5ddd"}
{"name":"\u4f60\u731c","age":19,"city":"\u56db\u5ddd"}
skipkeys:默認值是False,如果dict的keys內的數據不是python的基本類型(str,unicode,int,long,float,bool,None),設置為False時,就會報TypeError的錯誤。此時設置成True,則會跳過這類key 。
ensure_ascii=True:默認輸出ASCLL碼,如果把這個該成False,就可以輸出中文。
check_circular:如果check_circular為false,則跳過對容器類型的循環引用檢查,循環引用將導致溢出錯誤(或更糟的情況)。
allow_nan:如果allow_nan為假,則ValueError將序列化超出范圍的浮點值(nan、inf、-inf),嚴格遵守JSON規范,而不是使用JavaScript等價值(nan、Infinity、-Infinity)。
default:default(obj)是一個函數,它應該返回一個可序列化的obj版本或引發類型錯誤。默認值只會引發類型錯誤。