鱼C论坛

 找回密码
 立即注册
查看: 11038|回复: 11

[作品展示] pickle多次dump后的load问题

[复制链接]
发表于 2015-6-15 22:16:22 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
在之前学习中,我发现 如果对同一个文件多次dump之后load出来的数据好像不全,发帖问题求助 http://bbs.fishc.com/thread-61967-1-1.html可惜没人鸟咱。所以我就慢慢研究了下,刚刚突然毛瑟顿开 特来分(zhuang)享(bi)下.

之前我发现像这样
  1. pkfile=open("data.txt",'ab')
  2. pickle.dump(data1,pkfile)
  3. pickle.dump(data2,pkfile)
  4. pkfile.close()
复制代码
之后与这样
  1. pkfile=open("data.txt",'ab')
  2. pickle.dump(data1,pkfile)
  3. pkfile.close()
复制代码
load出来的结果是一样的,但是看文件data.txt的大小确实不同 而且扔到winhex里也确实内容有变多(详细可以看下之前的那个帖子http://bbs.fishc.com/thread-61967-1-1.html)  可能我们都是习惯把数据修改好再重新dump覆盖掉之前的,可是如果真的需要追回并且一定要load出来改怎么办呢   

刚刚突然脑洞大开   我们正常dump一次 所以load一次就好了   这里我dump了两次 是不是要load两次才能把数据读出来呢。。。。果断试了下,代码:
  1. import pickle
  2. data1 = {'a': [1, 2.0, 3, 4+6j],
  3.          'b': ('string', u'Unicode string'),
  4.          'c': None}
  5. data2 = {'aa': [1, 2.0, 3, 4+6j],
  6.          'bb': ('string', u'Unicode string'),
  7.          'cc': None}

  8. pkfile=open("data.txt",'ab')
  9. pickle.dump(data1,pkfile)
  10. pickle.dump(data2,pkfile)
  11. pkfile.close()

  12. pkfile2=open("data.txt",'rb')
  13. pkf=pickle.load(pkfile2)
  14. pkf1=pickle.load(pkfile2)

  15. print(pkf)
  16. print(pkf1)
复制代码


结果 1111.jpg

第一次这样写  可能写的有点乱  而且自己这样分析也不一定对欢迎指导
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-9-22 17:03

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表