Pickle

原文出处: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模块的安全和限制。

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值