使用python3.8+(默认协议=5)时,在来自python3.7的(协议=4)对象上,ickle.load失败。
问题描述
在Python3.4到3.7中,Python将其PICKLE协议更改为4,并在Python3.8中再次将其更改为PROTOCOL=5。如何在Python3.8中打开较旧的腌制文件?我已尝试:
>>> with open('data_frame_111.pkl','rb') as pfile:
... x1 = pickle.load(pfile)
...
Traceback (most recent call last):
File "<stdin>", line 2, in <module>
AttributeError: Can't get attribute 'new_block' on <module
'pandas.core.internals.blocks' from '/opt/anaconda3/lib/python3.8/site-
packages/pandas/core/internals/blocks.py'>
和
>>> with open('data_frame_111.pkl','rb') as pfile:
... x1 = unpkl.load(pfile, protocol=4)
但是,协议是pickle.dump
中的关键字,而不是pickle.load
的一部分。实例化pickle.Unpickler()
也不起作用。但显然应该有办法。
在python3.7中,我会import pickle5
并使用它打开较新的泡菜,但找不到在python3.8中执行相反操作的文档。
解决方案
您需要升级到 pandas 的最新版本(我支持1.3.1)。或者,更准确地说,您执行pickle.dump(some_path)
操作时的 pandas 版本应与您将执行pickle.load(some_path)
操作时的 pandas 版本相同。
相关文章