如果JSON中包含中文字符,我们将其写入文件中会怎样呢?
import json
data = [{
'name': '张三',
'gender': '男',
'birthday': '1992-11-11'
}]
with open('data.json', 'w') as file:
file.write(json.dumps(data, indent=2))
参数indent指定缩进数。
运行之后,结果如下:
[
{
"name": "\u5f20\u4e09",
"gender": "\u7537",
"birthday": "1992-11-11"
}
]
可以看到结果中,中文字符都变成了unicode字符,这个显然不是我们想要的结果。
那么我们需要怎么操作呢?
为了输出中文,需要指定参数ensure_ascii为False并且还要规定文件输出的编码:
with open('data.json', 'w', encoding='utf-8') as file:
file.write(json.dumps(data, indent=2, ensure_ascii=False))
修改之后的结果如下:
[
{
"name": "张三",
"gender": "男",
"birthday": "1992-11-11"
}
]
这下中文字符就正常的保存下来了。
本文深入探讨了在使用Python处理包含中文字符的JSON数据时,如何正确地保存和读取中文字符,避免出现乱码问题。文章通过具体示例,演示了如何设置参数以确保中文字符能够被正常保存。
343

被折叠的 条评论
为什么被折叠?



