原文出处:https://www.cnblogs.com/zrmw/p/11527410.html
Python中的pickle模块详解-Python教程-PHP中文网
# -*- coding:utf-8 -*-
import pickle
obj = 456, "abcdef", ["ac", 456], {"key": "value", "key3": "value2"}
print(obj)
# 序列化到文件
with open(r"D:\python_oop_20231206\debugwm\dianliang.TXT", "wb") as f:
pickle.dump(obj, f)
with open(r"D:\python_oop_20231206\debugwm\dianliang.TXT", "rb") as f:
print(pickle.load(f))# 输出:(123, 'abcdef', ['ac', 123], {'key': 'value', 'key1': 'value1'})
# 序列化到内存(字符串格式保存),然后对象可以以任何方式处理如通过网络传输
obj1 = pickle.dumps(obj)
print(type(obj1))# 输出<class 'bytes'>
print(obj1)# 输出:python专用的存储格式 b'\x80\x03(K{X\x06\x00\x00\x00abcdefq\x00]q\x01(X\x02\x00\x00\x00acq\x02K{e}q\x03(X\x03\x00\x00\x00keyq\x04X\x05\x00\x00\x00valueq\x05X\x04\x00\x00\x00key1q\x06X\x06\x00\x00\x00value1q\x07utq\x08.'
obj2 = pickle.loads(obj1)
print(type(obj2))# 输出:<class 'tuple'>
print(obj2) # 输出:(123, 'abcdef', ['ac', 123], {'key': 'value', 'key1': 'value1'})
#需要注意的是,使用pickle模块需要谨慎,因为pickle模块是不安全的。当pickle模块序列化Python对象时,它会将所有的代码以及引用的内部对象都一起序列化。由于pickle模块可以加载任何Python代码,因此使用pickle序列化对象时,有可能存在安全漏洞和代码注入问题。因此,应该避免在不可信的环境下使用pickle模块。
# 另外,pickle模块不能序列化所有的Python对象类型,例如生成器、迭代器等。因此,在使用pickle模块时应该注意这些限制。
#
# 总结
#
# pickle模块提供了Python对象的序列化和反序列化功能,可以将Python对象转换为二进制字节流保存到文件或通过网络传输。pickle模块广泛应用于Python程序中,尤其是在对象持久化、网络传输和数据分析等场景中。但是,需要注意pickle模块的安全和限制。