關於json.dumps中的參數,例如ensure_ascii


通過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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM