# 1. 什么是序列化
序列化指的是把内存中的数据类型转换成一个特定格式的内容,该格式的内容可用于存储或者转给其他平台使用
内存中的数据-->序列化-->特定的格式(json格式或pickle格式)
反序列化:内存中的数据<--序列化<--特定的格式(json格式或pickle格式)
# 2. 为何要序列化
序列化得到结果==>特定格式的内容有两种用途:
(1).用于存储==>用于存档
(2).转给其他平台使用 ==>跨平台数据交互
python ————————————————>Java
列表 ————特定格式—————>数组
强调:针对(2)中的特定格式,应该是一种通用,能够被所有语言识别的格式————json格式
针对(1)中的特定格式,可以是一种专用的格式————>pickle,只有python能用
# 3. 如何序列化与反序列化
import json
(1)序列化
res = json.dumps(True) # 结果:true <class 'str'>
print(res, type(res))
(2)将序列化结果写入文件的复杂方法
json_res1 = json.dumps([1, 2, 'abc', True, False]) # 结果:[1, 2, "abc", true, false] <class 'str'>
with open('test_json', mode = 'wt', encoding = 'utf-8') as f:
f.write(json_res1) # 写入的文件是json格式
(3)从文件读取json格式文件进行反序列化的复杂操作
with open('test_json', mode = 'rt', encoding = 'utf-8') as f:
res = f.read() # 写入的文件是json格式
lis = json.loads(res)
print(lis) # 结果:[1, 2, 'abc', True, False]
(4)反序列化
lis = json.loads(json_res1)
print(lis) # 结果:[1, 2, 'abc', True, False]
(5)将序列化结果写入文件的简单方法:
with open('test_json', mode = 'wt', encoding = 'utf-8') as f:
json.dump([1, 2, 'abc', True, False], f)
(6)从文件读取json格式文件进行反序列化的简单操作
with open('test_json', mode = 'rt', encoding = 'utf-8') as f:
lis = json.load(f)
print(lis) # 结果:[1, 2, 'abc', True, False]
(7)json验证:json格式兼容的是所有语言通用的数据类型,对于单一语言特有的数据类型不识别
json.dumps({1, 2, 3, 4, 5}) # TypeError: Object of type set is not JSON serializable
json格式的字符串必须是英文双引号
以二进制格式打开json文件,并将其进行反解;在python2.7与3.6之后的版本都可以,唯独3.5不可以
with open('test_json', mode = 'rb') as f:
l = json.load(f)
print(l)
(8)猴子补丁:用自己的代码替换所用模块的源代码
功能:一切皆对象
在首次导入模块的时候打补丁
import json
import ujson
def monkey_patch_json():
json__name__ = 'ujson'
json.loads = ujson.loads
json.dumps = ujson.dumps
monkey_patch_json() # 在入口程序文件执行
python之数据序列化
最新推荐文章于 2024-07-31 15:55:27 发布