使用python3.8+(默认协议=5)时,在来自python3.7的(协议=4)对象上,ickle.load失败。

2022-04-07 00:00:00 python pickle python-3.8

问题描述

在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 版本相同。

相关文章