pickle.dump()和pickle.load()进行文件操作

文章目录


pickle模块实现了用于序列化和反序列化Python对象结构的二进制协议。

  • 序列化:把对象转换为字节序列的过程称为对象的序列化。可以将对象信息永久存储

  • 反序列化:把字节序列恢复为对象的过程称为对象的反序列化。创建上一次程序保存的对象

序列化:

pickle.dump(obj, file,protocol)

注解:将对象obj保存到文件file中去。

  • file必须有write()接口, file可以是一个以’w’方式打开的文件或者一个StringIO对象或者其他任何实现write()接口的对象。
  • protocol为序列化使用的协议版本,
  • 0:ASCII协议,所序列化的对象使用可打印的ASCII码表示;
  • 1:老式的二进制协议;
  • 2:2.3版本引入的新二进制协议,较以前的更高效。
  • protocol默认值为0。
import pickle

#使用pickle模块将数据对象保存到文件

data1 = {'a': [1, 2.0, 3, 4+6j],
         'b': ('string', u'Unicode string'),
         'c': None}

selfref_list = [1, 2, 3]
selfref_list.append(selfref_list[:])

output = open('data.txt', 'wb')

# pickle字典使用协议0。
pickle.dump(data1, output)

# 使用可用的最高协议Pickle列表。
pickle.dump(selfref_list, output, -1)

output.close()

反序列化:

pickle.load(file)
#使用pickle模块从文件中重构python对象
pkl_file = open('data.txt', 'rb')

data1 = pickle.load(pkl_file)

print(data1)

data2 = pickle.load(pkl_file)
print(data2)

pkl_file.close()
{'a': [1, 2.0, 3, (4+6j)], 'b': ('string', 'Unicode string'), 'c': None}
[1, 2, 3, [1, 2, 3]]

什么情况下需要序列化?

  • 当你想把的内存中的对象状态保存到一个文件中或者数据库中时候;
  • 当你想用套接字在网络上传送对象的时候;
  • 当你想通过RMI传输对象的时候;
  • (最常用的可能就存数据库的)
  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

炫云云

你的鼓励是我创作最大的动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值