Python3中的json.dumps后,中文为Unicode编码问题处理

一、原因

  • Python3 已经将Unicode作为默认编码,进行操作;
  • Python3 中的json在做dumps操作时,会将中文自动转换成Unicode编码,然后再做逆向操作时,会将Unicode编码重新转换回中文。

二、解决方案

  • Python3中,json.dumps中有一个参数:ensure_ascii,可以对自动转换操作进行控制,该参数默认值为True,所以进行dumps时如果无此参数,就默认进行转换。在后面加上该参数,并设置为False,该自动转换就被停止,就可以正常显示中文了
  • 举个栗子:
# 未加参数:ensure_ascii
a = {'name': '张三', 'age': 14, 'grade_name': '三年级'}
a = json.dumps(a)
打印的结果:{"name": "\u5f20\u4e09", "age": 14, "grade_name": "\u4e09\u5e74\u7ea7"}

# 加上参数:ensure_ascii=False
b = {'name': '张三', 'age': 14, 'grade_name': '三年级'}
b = json.dumps(b, ensure_ascii=False)
打印的结果:{"name": "张三", "age": 14, "grade_name": "三年级"}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
禁止转载,如需转载请通过简信或评论联系作者。

友情链接更多精彩内容