2013-10-17
Posted by yeho

Python序列化的概念很简单。内存里面有一个数据结构,你希望将它保存下来,重用,或者发送给其他人。你会怎么做?这取决于你想要怎么保存,怎么重用,发送给谁。很多游戏允许你在退出的时候保存进度,然后你再次启动的时候回到上次退出的地方。(实际上,很多非游戏程序也会这么干)在这种情况下,一个捕获了当前进度的数据结构需要在你退出的时候保存到硬盘上,接着在你重新启动的时候从硬盘上加载进来。

Python标准库提供pickle和cPickle模块。cPickle是用C编码的,在运行效率上比pickle要高,但是cPickle模块中定义的类型不能被继承(其实大多数时候,我们不需要从这些类型中继承,推荐使用cPickle)。cPickle和pickle的序列化/反序列化规则是一样的,使用pickle序列化一个对象,可以使用cPickle来反序列化。同时,这两个模块在处理自引用类型时会变得更加“聪明”,它不会无限制的递归序列化自引用对象,对于同一对象的多次引用,它只会序列化一次。

pickle模块中的两个主要函数是dump()和load()。dump()函数接受一个数据对象和一个文件句柄作为参数,把数据对象以特定的格式保存到给定的文件中。当我们使用load()函数从文件中取出已保存的对象时,pickle知道如何恢复这些对象到它们本来的格式。

dumps()函数执行和dump()函数相同的序列化。取代接受流对象并将序列化后的数据保存到磁盘文件,这个函数简单的返回序列化的数据。
loads()函数执行和load()函数一样的反序列化。取代接受一个流对象并去文件读取序列化后的数据,它接受包含序列化后的数据的str对象, 直接返回的对象。

cPickle.dump(obj, file, protocol=0)
序列化对象,并将结果数据流写入到文件对象中。参数protocol是序列化模式,默认值为0,表示以文本的形式序列化。protocol的值还可以是1或2,表示以二进制的形式序列化。

cPickle.load(file)
反序列化对象。将文件中的数据解析为一个Python对象。

下面通过一个简单的例子来演示上面两个方法的使用:

>>> import pickle,cPickle
>>> info_dict = {'name':'yeho','age':100,'Lang':'Python'}
>>> f = open('info.pkl','wb')
>>> pickle.dump(info_dict,f)
>>> f.close()
>>> exit()
# cat info.pkl
(dp0
S'Lang'
p1
S'Python'
p2
sS'age'
p3
I100
sS'name'
p4
S'yeho'
p5
s.
>>> import cPickle
>>> info_dict
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'info_dict' is not defined
>>> f = open('info.pkl','r+')
>>> info2_dict = cPickle.load(f)
>>> info2_dict
{'Lang': 'Python', 'age': 100, 'name': 'yeho'}
>>> info2_dict['age'] = 110
>>> cPickle.dump(info2_dict,f)
>>> f.close()
>>> exit()
>>> import pickle
>>> f = open('info.pkl','r+')
>>> info_dict = pickle.load(f)
>>> info_dict
{'Lang': 'Python', 'age': 100, 'name': 'yeho'}
>>> info2_dict = pickle.load(f)
>>> info2_dict
{'Lang': 'Python', 'age': 110, 'name': 'yeho'}
>>> info3_dict = pickle.load(f)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib64/python2.6/pickle.py", line 1370, in load
return Unpickler(file).load()
File "/usr/lib64/python2.6/pickle.py", line 858, in load
dispatch[key](self)
File "/usr/lib64/python2.6/pickle.py", line 880, in load_eof
raise EOFError
EOFError

最新文章

  1. ReactNative中iOS和Android的style分开设置教程
  2. Linux下使用 Memory Analyzer
  3. Charles
  4. Java 动态代理
  5. 知识积累:DAS NAS SAN
  6. codeforces B. Flag Day 解题报告
  7. DOM之兄弟节点
  8. Windows Store App 应用程序存储空间
  9. hello world of hibernate Annotation
  10. Debian 6解决中文乱码
  11. 导出到excel
  12. 【转】Linux中断处理学习笔记
  13. hdoj 1052 Tian Ji -- The Horse Racing【田忌赛马】 【贪心】
  14. servlet+jsp update修改页面的实现,整整搞了两个小时才搞定
  15. ASP.NET Core的身份认证框架IdentityServer4(6)- 开始
  16. TCP-IP详解笔记6
  17. centos7进单用户
  18. SpringBoot 配置 Servlet、Filter、Listener
  19. __getitem__ __setitem__ __delitem__ 使用
  20. 网络基础&#160;http&#160;会话(session)详解

热门文章

  1. WPF DevExpress Chart控件 需要引用的类库
  2. 关于自定义 List集合排序的方法!
  3. Selenium学习之==&gt;三种等待方式
  4. springboot文件上传报错
  5. C# DES 加解密
  6. Python文档操作
  7. 刘铁猛-深入浅出WPF-系列资源汇总
  8. 方便测试和调用webservice的工具(转)
  9. MySQL-快速入门(5)数据查询-常用关键字、分组查询、聚合函数
  10. 树形dp相关