示例代码:
>>> import json >>> json_string = json.dumps("讘专讬 爪拽诇讛") >>> print(json_string) "\u05d1\u05e8\u05d9 \u05e6\u05e7\u05dc\u05d4"
问题:它不是人类可读的。我的(聪明的)用户想要验证甚至编辑带有 JSON 转储的文本文件(我宁愿不使用 XML)。
有没有办法将对象序列化为 UTF-8 JSON 字符串(而不是 \uXXXX)?
\uXXXX
使用ensure_ascii=False切换到json.dumps(),然后手动将值编码为 UTF-8:
ensure_ascii=False
json.dumps()
>>> json_string = json.dumps("ברי צקלה", ensure_ascii=False).encode('utf8') >>> json_string b'"\xd7\x91\xd7\xa8\xd7\x99 \xd7\xa6\xd7\xa7\xd7\x9c\xd7\x94"' >>> print(json_string.decode()) "ברי צקלה"
如果您正在写入文件,只需使用json.dump()并将其留给文件对象进行编码:
json.dump()
with open('filename', 'w', encoding='utf8') as json_file: json.dump("ברי צקלה", json_file, ensure_ascii=False)
Python 2 的注意事项
对于 Python 2,还有一些注意事项需要考虑。如果要将其写入文件,则可以使用io.open()而不是open()生成一个文件对象,该对象在您写入时为您编码 Unicode 值,然后使用json.dump()而不是写入该文件:
io.open()
open()
with io.open('filename', 'w', encoding='utf8') as json_file: json.dump(u"ברי צקלה", json_file, ensure_ascii=False)
请注意,模块中存在一个错误,其中json标志可以ensure_ascii=False产生混合对象。Python 2 的解决方法是:unicode``str
json
unicode``str
with io.open('filename', 'w', encoding='utf8') as json_file: data = json.dumps(u"ברי צקלה", ensure_ascii=False) # unicode(data) auto-decodes data to unicode if str json_file.write(unicode(data))
在 Python 2 中,当使用编码为 UTF-8 的字节字符串(类型str)时,请确保同时设置encoding关键字:
str
encoding
>>> d={ 1: "ברי צקלה", 2: u"ברי צקלה" } >>> d {1: '\xd7\x91\xd7\xa8\xd7\x99 \xd7\xa6\xd7\xa7\xd7\x9c\xd7\x94', 2: u'\u05d1\u05e8\u05d9 \u05e6\u05e7\u05dc\u05d4'} >>> s=json.dumps(d, ensure_ascii=False, encoding='utf8') >>> s u'{"1": "\u05d1\u05e8\u05d9 \u05e6\u05e7\u05dc\u05d4", "2": "\u05d1\u05e8\u05d9 \u05e6\u05e7\u05dc\u05d4"}' >>> json.loads(s)['1'] u'\u05d1\u05e8\u05d9 \u05e6\u05e7\u05dc\u05d4' >>> json.loads(s)['2'] u'\u05d1\u05e8\u05d9 \u05e6\u05e7\u05dc\u05d4' >>> print json.loads(s)['1'] ברי צקלה >>> print json.loads(s)['2'] ברי צקלה