json.dumps()序列化,存储。(对数据进行编码,形成json格式的数据)
import json
dic = {"spring":("微风","细雨","暖阳")}
ret = json.dumps(dic) # 序列化
print(type(dic),dic) # <class 'dict'> {'spring': ('微风', '细雨', '暖阳')}
print(type(ret),ret) # <class 'str'> {"spring": ["\u5fae\u98ce", "\u7ec6\u96e8", "\u6696\u9633"]}
从结果中,可以看出:原始数据类型是字典,序列化之后,就是字符串类型。而且中文变成了看不懂的字符串。这是因为json.dumps 序列化时对中文默认使用的ascii编码。
想输出真正的中文需要指定ensure_ascii=False
dic = {"spring":('微风','细雨','暖阳')}
ret = json.dumps(dic,ensure_ascii=False) # 序列化时,不使用ascii码
print(type(dic),dic) # <class 'dict'> {'spring': ('微风', '细雨', '暖阳')}
print(type(ret),ret) # <class 'str'> {"spring": ["微风", "细雨", "暖阳"]}
json.loads()反序列化,读取。(和dumps相反,loads函数则是将json格式的数据解码,转换为Python字典)
import json
dic = [1,['a','b','c'],3,{'k1':'v1','k2':'v2'}]
ret = json.dumps(dic,ensure_ascii=False) # 序列化时,不使用ascii码
res = json.loads(ret) # 反序列化
print(type(ret),ret) # <class 'str'> [1, ["a", "b", "c"], 3, {"k1": "v1", "k2": "v2"}]
print(type(res),res) # <class 'list'> [1, ['a', 'b', 'c'], 3, {'k1': 'v1', 'k2': 'v2'}]
json.dump() 将序列化内容写入文件
import json
dic = {"spring":("春天"),"summer":("夏天"),"autumn":("球天"),"winter":("冬天")}
f = open('test.txt','w',encoding='utf-8')
#dump方法接收一个文件句柄,直接将字典转换成json字符串写入文件
json.dump(dic,f) # 先接收要序列化的对象,再接收文件句柄
f.close()
# 执行程序,查看文件内容为:{"spring": "\u6625\u5929", "summer": "\u590f\u5929", "autumn": "\u7403\u5929", "winter": "\u51ac\u5929"}
# 要想文件写入中文,可以加参数ensure_ascii=False
import json
dic = dic = {"spring":("春天"),"summer":("夏天"),"autumn":("球天"),"winter":("冬天")}
f = open('test.txt','w',encoding='utf-8')
json.dump(dic,f,ensure_ascii=False)
f.close()
#执行程序,再次查看文件内容:{"spring": "春天", "summer": "夏天", "autumn": "球天", "winter": "冬天"}
json.load() 读取文件中的序列化内容
import json
dic = {"spring":("春天"),"summer":("夏天"),"autumn":("球天"),"winter":("冬天")}
f = open('test.txt','r',encoding='utf-8')
# load方法接收一个文件句柄,直接将文件中的json字符串转换成数据结构返回
ret = json.load(f) #接收文件句柄
print(type(ret),ret) # 查看内容
f.close() # 最后记得关闭文件句柄
# 执行输出:<class 'dict'> {'spring': '春天', 'summer': '夏天', 'autumn': '球天', 'winter': '冬天'}
dump和load 依赖一个文件句柄
下面有4个字典,如何写入文件?使用常规方法json.dump一行行写入,再次读取时,会报错。
dic1 = {"spring":"春天"}
dic2 = {"summer":"夏天"}
dic3 = {"autumn":"球天"}
dic4 = {"winter":"冬天"}
写入多行
import json
dic1 = {"spring":"春天"}
dic2 = {"summer":"夏天"}
dic3 = {"autumn":"球天"}
dic4 = {"winter":"冬天"}
f = open('season','a',encoding='utf-8')
f.write(json.dumps(dic1)+'\n') # 写入一行内容,注意,一定要加换行符
f.write(json.dumps(dic2)+'\n')
f.write(json.dumps(dic3)+'\n')
f.write(json.dumps(dic4)+'\n')
f.close() # 关闭文件句柄
# 执行程序,文件内容
'''
{"spring": "\u6625\u5929"}
{"summer": "\u590f\u5929"}
{"autumn": "\u7403\u5929"}
{"winter": "\u51ac\u5929"}
'''
读取多行文件内容
import json
f = open('season','r',encoding='utf-8')
for i in f:
print(json.loads(i.strip()))
f.close()
# 执行程序,文件内容
'''
{'spring': '春天'}
{'summer': '夏天'}
{'autumn': '球天'}
{'winter': '冬天'}
'''
注意:json不支持元组 不支持除了str数据类型之外的key
总结:
- dumps序列化 loads反序列化 只在内存中操作数据 主要用于网络传输 和多个数据与文件打交道
- dump序列化 load反序列化 主要用于一个数据直接存在文件里—— 直接和文件打交道