开发者

python使用json.dumps输出中文问题

开发者 https://www.devze.com 2023-02-09 09:37 出处:网络 作者: 林新发
目录使用json.dumps输出中文python json.dumps()中文乱码总结使用json.dumps输出中文 在使用json.dumps时要注意一个问题
目录
  • 使用json.dumps输出中文
  • python json.dumps()中文乱码
  • 总结

使用json.dumps输出中文

在使用json.dumps时要注意一个问题

>>> import json
>>> print(json.dumps('中国'))
"\u4e2d\u56fd"

输出的会是

‘中国’ 中的ascii字符码,而不是真正的中文。

这是因为json.dumps序列化时对中文默认使用的ascii编码

想输出真正的中文需要指定ensure_ascii=False:

>>&g开发者_开发入门t; import json
>>> print(json.dumps('中国'))
"\u4e2d\u56fd"
>>> print(json.dumps('中国', ensure_ascii=False))
"中国"

Python json.dumps()中文乱码

有一段代码如下:

        def save_data(self,data):
            print(data)
            #ensure_ascii=False
            data=json.dumps(data)
            print(data)
            with open('ljd.json',mode='w',enwww.devze.comcoding='utf-8') as f:
                f.write(data)

date在传递进来之前是字典格式数据,现在为了能保存到文件中,因此用json.dumps(djavascriptata)来将字典数据转换为json字符串,但是转换以后前后显示就有问题了,如下:

python使用json.dumps输出中文问题

发现转换以后,中文乱码了。

原因:json.dumps 序列化时默认使用的ascii编码,想输出真正的中文需要指定ensure_ascii=False:更深入分析,是应为dJSON object 不是单纯的unicode实现,而是包含了混合的unicode编码以及已经用utf-8编码之后的字符串。

更改如下:

        def save_data(self,data):
            print(data)
            #ensurebTffGeZJG_awww.devze.comscii=False
            data=json.dumps(data,ensure_ascii=False)
            prjsint(data)
            with open('ljd.json',mode='w',encoding='utf-8') as f:
                f.write(data)

而后,显示正常!

python使用json.dumps输出中文问题

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

0

精彩评论

暂无评论...
验证码 换一张
取 消