首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用python 3.8+ (默认protocol=5)时,pickle.load在Python3.7中的(protocol=4)对象上失败

使用python 3.8+ (默认protocol=5)时,pickle.load在Python3.7中的(protocol=4)对象上失败
EN

Stack Overflow用户
提问于 2021-07-17 03:55:51
回答 2查看 4.8K关注 0票数 6

Python在Python3.4到3.7中将其pickle协议更改为4,并在Python3.8中再次将其更改为protocol=5。如何在python 3.8中打开较旧的酸洗文件?

我试过了:

代码语言:javascript
运行
复制
>>> 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'>

代码语言:javascript
运行
复制
>>> 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并使用它来打开较新的pickles,但在Python3.8中找不到相反的文档。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-07-29 15:18:50

你需要升级到pandas的最新版本(对我来说是1.3.1)。或者,更准确地说,您执行pickle.dump(some_path)时的pandas版本应该与您将执行pickle.load(some_path)时的pandas版本相同。

票数 4
EN

Stack Overflow用户

发布于 2021-07-23 01:35:56

代码语言:javascript
运行
复制
with open('data_frame_111.pkl','rb') as pfile:
    x1 = pickle.load(pfile)

尝试更改为:

代码语言:javascript
运行
复制
import pandas as pd
with open('data_frame_111.pkl','rb') as pfile:
    x1 = pd.read_pickle(pfile)

由于安全漏洞的考虑,似乎已经有了一些变化。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68414632

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档