通過help(“json”) 看到里面有一個配置信息,
<span style="font-family:Microsoft YaHei;font-size:18px;">
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)
</span>
編碼后的json格式字符串緊湊的輸出,而且也沒有順序,因此dumps方法提供了一些可選的參數,讓輸出的格式提高可讀性。
(1)sort_keys是告訴編碼器按照字典排序(a到z)輸出。
import json
data = [ { 'a':'A', 'b':(2, 4), 'c':3.0 } ]
print 'DATA:', repr(data)
unsorted = json.dumps(data)
print 'JSON:', json.dumps(data)
print 'SORT:', json.dumps(data, sort_keys=True)
輸出:
DATA: [{'a': 'A', 'c': 3.0, 'b': (2, 4)}]
JSON: [{"a": "A", "c": 3.0, "b": [2, 4]}]
SORT: [{"a": "A", "b": [2, 4], "c": 3.0}
(2)indent參數根據數據格式縮進顯示,讀起來更加清晰:
indent的數值,代表縮進的位數
import json
data = [ { 'a':'A', 'b':(2, 4), 'c':3.0 } ]
print 'DATA:', repr(data)
print 'NORMAL:', json.dumps(data, sort_keys=True)
print 'INDENT:', json.dumps(data, sort_keys=True, indent=2)
輸出:
DATA: [{'a': 'A', 'c': 3.0, 'b': (2, 4)}]
NORMAL: [{"a": "A", "b": [2, 4], "c": 3.0}]
INDENT: [
{
"a": "A",
"b": [
2,
4
],
"c": 3.0
}
]
(3)separators參數的作用是去掉,,:后面的空格,從上面的輸出結果都能看到”, :”后面都有個空格,這都是為了美化輸出結果的作用,但是在我們傳輸數據的過程中,越精簡越好,冗余的東西全部去掉,因此就可以加上.
data = [ { 'a':'A', 'b':(2, 4), 'c':3.0 } ]
print 'DATA:', repr(data)
print 'repr(data) :', len(repr(data))
print 'dumps(data) :', len(json.dumps(data))
print 'dumps(data, indent=2) :', len(json.dumps(data, indent=2))
print 'dumps(data, separators):', len(json.dumps(data, separators=(',',':')))
print json.dumps(data, sort_keys=True)
print json.dumps(data, sort_keys=True, separators=(',',':'))
輸出結果為:
DATA: [{'a': 'A', 'c': 3.0, 'b': (2, 4)}]
repr(data) : 35
dumps(data) : 35
dumps(data, indent=2) : 76
dumps(data, separators): 29
[{"a": "A", "b": [2, 4], "c": 3.0}]
[{"a":"A","b":[2,4],"c":3.0}]
(4)skipkeys參數,在encoding過程中,dict對象的key只可以是string對象,如果是其他類型,那么在編碼過程中就會拋出ValueError的異常。skipkeys可以跳過那些非string對象當作key的處理.
data2 = [ { 'a':'A', 'b':(2, 4), 'c':3.0, ('d',):'D tuple' } ]
try:
print json.dumps(data2)
except (TypeError, ValueError) as err:
print 'ERROR:', err
print
print json.dumps(data2, skipkeys=True)
>>輸出結果為:
>ERROR: keys must be a string
[{"a": "A", "c": 3.0, "b": [2, 4]}]
(5)輸出真正的中文需要指定ensure_ascii=False
如果無任何配置,或者說使用默認配置,
輸出的會是‘涼涼’的ASCII字符嗎,而不是真正的中文。
這是因為json.dumps 序列化時對中文默認使用的ascii編碼。
import json
print json.dumps('涼涼')
>> "\u51c9\u51c9"
想輸出真正的中文需要指定ensure_ascii=False:
print json.dumps('涼涼', ensure_ascii=False)
>> 涼涼
原文鏈接:https://blog.csdn.net/liangxy2014/article/details/78985057