1、简述
- Python中的
pickle
模块实现了基本的数据序列化
与反序列化
。 - 序列化对象可以在磁盘上保存对象,并在需要的时候读取出来,反序列化适合程序直接应用。
2、详解dump()方法
2.1 dump()方法
pickle.dump(obj, file, [,protocol])
obj
–序列化对象,将对象obj保存到文件file中去;file
–表示保存到的类文件对象,file必须有write()接口,file可以是一个以’w’或’wb’打开的文件或者是一个StringIO对象,也可以是任何可以实现write()接口的对象;protocol
——序列化模式,默认是 0(ASCII协议,表示以文本的形式进行序列化),protocol的值还可以是1和2(1和2表示以二进制的形式进行序列化)。
2.2 示例
xp = XmlProcess("./commodity/Annotations/")
xp.process_xml()
pickle.dump(xp.data, open("./commodity_gt.pkl", 'wb'))
此处是计算机视觉中处理xml文件的部分代码,所以是采用的实例化的方式传入对象;xp部分可以是读取的本地文件,也可以是程序的某个对象。
生成文件如下:
3、详解 load()方法
3.1load()方法
pickle.load(file)
- 反序列化对象,将文件中的数据解析为一个python对象。
- file中有read()接口和 readline() 接口
3.2 示例
result = pickle.load(open("./commodity_gt.pkl", "rb"))
print(result)
print
的结果如下
此处print的结果便是存储的内容