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()
仅返回 list
的 tuples
, 是可腌制的。
在 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 对象的主要内容,如果未能解决你的问题,请参考以下文章
PySpark / Glue:PicklingError:无法序列化对象:TypeError:无法腌制thread.lock对象
_pickle.PicklingError:无法序列化对象:TypeError:无法腌制_thread.RLock对象
多处理,Python3,Windows:TypeError:无法腌制 _thread.lock 对象
pickle.dump(模型,pickle_out)| TypeError:无法腌制 _thread._local 对象