截断和重写泡菜文件会引发 KeyError 'x00'



在转储数据后,我试图截断pickle文件,但它似乎不像.txt文件那样工作。

dic1 = {'a': 1, 'b': 2}
dic2 = {'c': 3, 'd': 4}
f = open("data.pk", "wb+")
pickle.dump(dic1, f)
f.truncate(0)
pickle.dump(dic2, f)
f.seek(0)
print pickle.load(f)
f.close()

此代码引发KeyError:"\x00"。truncate(0(似乎并没有截断文件,而是添加了一些字符,如"\x00"。

我可以删除pickle文件的内容而不关闭并重新打开它吗?

file.truncate更改文件大小,但根据文档

当前文件位置不会更改。

这可以通过在截断后调用文件的tell方法来证明。

>>> d1 = dict(a=1, b=2)
>>> d2 = dict(c=3, d=4) 
>>> with open('file.bin', 'wb+') as f:
...     pickle.dump(d1, f)
...     f.truncate(0)
...     print 'File pointer position:', f.tell()
...     pickle.dump(d2, f)
...     f.seek(0)
...     pickle.load(f)
... 
File pointer position: 30
Traceback (most recent call last):
File "<stdin>", line 7, in <module>
File "/usr/lib64/python2.7/pickle.py", line 1384, in load
return Unpickler(file).load()
File "/usr/lib64/python2.7/pickle.py", line 864, in load
dispatch[key](self)
KeyError: 'x00'

将文件指针重置到文件的开头会产生所需的行为*

>>> with open('file.bin', 'wb+') as f:
...     pickle.dump(d1, f)
...     f.truncate(0)
...     f.seek(0)
...     pickle.dump(d2, f)
...     f.seek(0)
...     pickle.load(f)
... 
{'c': 3, 'd': 4}

*至少,它在我的Linux机器上产生了所需的行为。对这个问题的评论中的讨论表明,这可能不适用于所有平台。

相关内容

  • 没有找到相关文章

最新更新