python字典保存为json后读取出错问题及解决
作者:xcliang9418
这篇文章主要介绍了python字典保存为json后读取出错问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
python字典保存为json后读取出错
json.load()读取json文件数据时,报错:XXXXXXXXX。
是因为在json文件中的引号为单引号,json.load()只能识别双引号。
避免报错的方式有三种
1、从保存文件时入手,刚开始就避免json文件中写入单引号。
json文件之所以写入单引号,大概率是在写入数据时,直接str(dict_data)字典转字符串,这种遗留问题就是不能用json.load()读取,写的时候应该用:json.dump(dict_data,file),一次写入到json文件中的字典是双引号的。
2、如果不想更换写入方式,或者数据是别人的,难么可以换读取方式。使用内置模块ast的literal_eval方法:
import ast ast.literal_eval(string)
3、直接使用python内置函数eval(string)
2和3的方法可以直接把字符串形式的json数据转为字典。
json文件转为str出现中文乱码问题
原来的代码是这样的
with open(fileName,'w',encoding='utf-8') as f: json.dump(AllResume,f)
当然用
temp = json.dumps(AllResume) with open(fileName,'w',encoding='utf-8') as f: f.write(temp) f.close()
得到的也是一样的结果。
出现的结果如下:
这是因为json.dumps或者json.dump 序列化时对中文默认使用的ascii编码,想输出真正的中文需要指定ensure_ascii=False:
with open(fileName,'w',encoding='utf-8') as f: json.dump(AllResume,f,ensure_ascii=False)
此时得到的结果才是:
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。