Python3 持久化pickle模块
pickle提供了一个简单的持久化功能。可以将对象以文件的形式存放在磁盘上。
1、pickle.dump(obj, file[, protocol])
序列化对象,并将结果数据流写入到文件对象中。参数protocol是序列化模式,默认值为0,表示以文本的形式序列化。protocol的值还可以是1或2,表示以二进制的形式序列化。
2、pickle.load(file)
反序列化对象。将文件中的数据解析为一个Python对象。
下面是dump 和 load方法演示:
>>> import pickle
>>> a1 = 'apple'
>>> b1 = {1: 'One', 2: 'Two', 3: 'Three'}
>>> c1 = ['fee', 'fie', 'foe', 'fum']
>>> pickle.dump(a1, f1)
Traceback (most recent call last):
File "<pyshell#24>", line 1, in <module>
pickle.dump(a1, f1)
TypeError: write() argument must be str, not bytes
>>> f1 = open('temp.pkl', 'wb') # 注意:Python3需要使用 'wb'模式写入文件,否则报错,如上所示
>>> pickle.dump(a1, f1)
>>> pickle.dump(b1, f1)
>>> pickle.dump(c1, f1)
>>> f1.close()
>>> f2 = open('temp.pkl', 'rb')
>>> a2 = pickle.load(f2)
>>> a2
'apple'
>>> b2 = pickle.load(f2)
>>> b2
{1: 'One', 2: 'Two', 3: 'Three'}
>>> c2 = pickle.load(f2)
>>> c2
['fee', 'fie', 'foe', 'fum']
>>> f2.close()