pickle简介
标准模块
pickle模块实现了基本的数据序列化和反序列化。通过pickle模块的序列化操作我们能够将程序中运行的对象信息,以二进制的形式保存到文件中去(保存文件的后缀为”.pkl”),永久存储;通过pickle模块的反序列化操作,我们能够从文件中创建上一次程序保存的对象。
这里注意,对于用户自行定义的对象,就必须要先定义类,然后才能从文件中载入对象。
pickle的文件中是这么说的:
”serializing”, “pickling", “marshalling” 或者”flattening”就是序列化
为什么要序列化和反序列化呢?
那么为什么需要序列化和反序列化这一操作呢?
1.便于存储。序列化过程将文本信息转变为二进制数据流。这样就信息就容易存储在硬盘之中,当需要读取文件的时候,从硬盘中读取数据,然后再将其反序列化便可以得到原始的数据。在Python程序运行中得到了一些字符串、列表、字典等数据,想要长久的保存下来,方便以后使用,而不是简单的放入内存中关机断电就丢失数据。python模块大全中的Pickle模块就派上用场了,它可以将对象转换为一种可以传输或存储的格式。
2.便于传输。当两个进程在进行远程通信时,彼此可以发送各种类型的数据。无论是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方需要把這个对象转换为字节序列,在能在网络上传输;接收方则需要把字节序列在恢复为对象。
# 举个栗子
import pickle
data = {
'a': [1, 2.0, 3, 4+6j],
'b': ('string', u'Unicode string'),
'c'