json 序列化 和反序列化
序列化:字典 / 列表 / 数字 /对象 -经过序列化 --->字符串
反序列化:字符串 ---> 字典 / 列表 / 数字 /对象
为什么要序列化
-
要把内容写入文件
-
网络传输数据 序列化
2. json序列化
用法区别:json.dumps( )是对json数据的操作。
json.dump( )是对json文件的读写操作
2.1 json.dumps()的使用
import json
data= {'name': 'ACME','shares': 100,'price': 542.23}
#json序列化---> 字典转化为字符串
json_str= json.dumps(data)
2.2 json.dump()的使用
#如果你要处理的是文件而不是字符串,你可以使用 json.dump() 和 json.load() #来编码和解码JSON数据。例如:
import json
data= {'name': 'ACME','shares': 100,'price': 542.23}
#打开一个json文件
with open('data.json', 'w') as f:
#将data数据以json的格式写入文件中
json.dump(data, f) #data数据格式为字典,第一个参数为要写入的内容,第二个参数为文件句柄
3. json反序列化
3.1 json.loads()
import json
data= """ {"name": "ACME", "shares": 100, "price": 542.23} """
#字符串转为字典
data_str = json.loads(data)
3.2 json.load()
json.load()用于从json文件中读取数据,json.load()之后的数据类型为字典
从文件里读取出来就是反序列化后的,用load,但是文件里的字符串必须是英文状态下的双引号,如果是单引号则会报错
import json
with open("data.json","r") as f :
data = json.load(f) #data为字典
4. json模块其他用法
4.1 json 格式的限制
# json格式的限制1,json格式的key必须是字符串数据类型
# json格式中的字符串只能是""
# set不能被dump/dumps
如果是数字为key,那么dumps之后会强行转成字符串数据类型
import json
dic = {1:2,3:4}
str_dic = json.dumps(dic)
print(str_dic)
new_dic = json.loads(str_dic)
print(new_dic)输出结果:
{"1": 2, "3": 4}
{'1': 2, '3': 4}
json支持元组做value,对元组做value的字典,会把元组强制转换成列表
import json
dic = {'abc': (1, 2, 3)}
str_dic = json.dumps(dic)
print(str_dic)
new_dic = json.loads(str_dic)
print(new_dic)输出结果:
{"abc": [1, 2, 3]}
{'abc': [1, 2, 3]}
json不支持元组做key
import json
dic = {(1, 2, 3): 'abc'}
str_dic = json.dumps(dic) # 报错
对列表的dump
import json
lst = ['aaa', 123, 'bbb', 12.456]
with open('json_demo', 'w') as f:
json.dump(lst, f)
with open('json_demo') as f:
ret = json.load(f)
print(ret)输出结果:
['aaa', 123, 'bbb', 12.456]
可以多次dump数据到文件里,但是不能load出来了
import json
dic = {'abc': (1, 2, 3)}
lst = ['aaa', 123, 'bbb', 12.456]
with open('json_demo', 'w') as f:
json.dump(lst, f)
json.dump(dic, f)
with open('json_demo') as f:
ret = json.load(f) # 会报错
print(ret)
想dump多个数据进入文件,用dumps
import json
dic = {'abc': (1, 2, 3)}
lst = ['aaa', 123, 'bbb', 12.456]
with open('json_demo', 'w') as f:
str_lst = json.dumps(lst)
str_dic = json.dumps(dic)
f.write(str_lst + '\n')
f.write(str_dic + '\n')
with open('json_demo') as f:
for line in f:
ret = json.loads(line)
print(ret)输出结果:
['aaa', 123, 'bbb', 12.456]
{'abc': [1, 2, 3]}
5.json的参数
5.1 json.dumps()参数解释
ensure_ascii=true
#出现中文乱码时可使用encure_ascii = false
ensure_ascii 默认为true
如果 ensure_ascii为 false,则返回值可以包含非 ASCII,如果它们出现在 obj 中包含的字符串中,则为字符。否则,所有此类字符在 JSON 字符串中进行转义。
如果sort_keys=True(默认值:False),则输出字典将按键排序。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具