TypeError:无法腌制 dict_items 对象

Posted

技术标签:

【中文标题】TypeError:无法腌制 dict_items 对象【英文标题】:TypeError: can't pickle dict_items objects 【发布时间】:2019-02-12 20:14:22 【问题描述】:

为什么

pickle.dumps(.items())

TypeError: can't pickle dict_items objects 在 Python 3.5.2 中失败,但在 Python 2.7.12 中失败?

用“腌制”字典

pickle.dumps()

适用于两个 Python 版本(在 Python 2.7.12 中提供与上述命令相同的输出)。

【问题讨论】:

【参考方案1】:

因为在 python 2.7 中,.items() 仅返回 listtuples 是可腌制的。

在 python 3.x 中,它返回一个 dict_items 对象(在 python 2 中不存在),不可选择(但更快,因为它不生成列表,它大致相当于 python 2.x @ 987654325@)。

但是你可以强制列表转换来模拟 python 2.x 的行为:

pickle.dumps(list(d.items()))

【讨论】:

不是一个令人满意的答案(我很抱歉在 8 年后打扰:-);它没有解释为什么它不起作用(不管它为什么在 PY2 上起作用),如果 dict_items 深埋在某些嵌套结构中,那么解决方法将毫无用处。 8 年后,我真的不知道你在说什么...dict_items 对象不可提取可能是因为 python 在 dict 哈希中引入了安全功能,这会使腌制数据在重新加载时无效。

以上是关于TypeError:无法腌制 dict_items 对象的主要内容,如果未能解决你的问题,请参考以下文章

TypeError:无法腌制 CompiledFFI 对象

PySpark / Glue:PicklingError:无法序列化对象:TypeError:无法腌制thread.lock对象

_pickle.PicklingError:无法序列化对象:TypeError:无法腌制_thread.RLock对象

多处理,Python3,Windows:TypeError:无法腌制 _thread.lock 对象

pickle.dump(模型,pickle_out)| TypeError:无法腌制 _thread._local 对象

TypeError:无法使用RQ腌制'_thread.lock'对象