pickle.dump()和pickle.load()进行文件操作
Posted 炫云云
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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传输对象的时候;
- (最常用的可能就存数据库的)
以上是关于pickle.dump()和pickle.load()进行文件操作的主要内容,如果未能解决你的问题,请参考以下文章
pickle load文件时报AttributeError: Can't get attribute 'Cours' on <module '__main__