python-pickle持久化存档

那么为什么需要序列化和反序列化这一操作呢?

便于存储。序列化过程将文本信息转变为二进制数据流。这样就信息就容易存储在硬盘之中,当需要读取文件的时候,从硬盘中读取数据,然后再将其反序列化便可以得到原始的数据。在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'}

 

posted @ 2019-02-14 10:57  jj千寻  阅读(148)  评论(0编辑  收藏  举报