那么为什么需要序列化和反序列化这一操作呢?
便于存储。序列化过程将文本信息转变为二进制数据流。这样就信息就容易存储在硬盘之中,当需要读取文件的时候,从硬盘中读取数据,然后再将其反序列化便可以得到原始的数据。在Python程序运行中得到了一些字符串、列表、字典等数据,想要长久的保存下来,方便以后使用,而不是简单的放入内存中关机断电就丢失数据。python模块大全中的Pickle模块就派上用场了,它可以将对象转换为一种可以传输或存储的格式。
注意:
只能在python中使用,只支持python的基本数据类型。
可以处理复杂的序列化语法。(例如自定义的类的方法,游戏的存档等)
序列化的时候,是序列化了整个序列对象,而不是内存地址。
1.保存bytes形式dumps()
把任意对象序列化成一个bytes,然后,就可以把这个bytes写入文件,或者通过网络传输。
import pickle
d = dict(name='Bob', age=20, score=88)
bts=pickle.dumps(d)
print type(bts)# 输出:<type 'str'>
#加载方式,读取bytes
bj2 = pickle.loads(bts)
print type(obj2)# 输出:<type 'tuple'>
print obj2# 输出:d {'age': 20, 'score': 88, 'name': 'Bob'}
2.文件形式,dump,load
直接把对象序列化后写入一个file-like Object:
f = open('dump.txt', 'wb')
pickle.dump(d, f)
f.close()
f = open('dump.txt', 'rb')
d = pickle.load(f)
f.close()
#d {'age': 20, 'score': 88, 'name': 'Bob'}