首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何通过搁置库使用dill库进行对象序列化

如何通过搁置库使用dill库进行对象序列化
EN

Stack Overflow用户
提问于 2018-10-22 18:32:06
回答 1查看 391关注 0票数 4

我正在使用PyMemoize库缓存协程。我装饰了协程,但是当Python调用它时,我得到:

代码语言:javascript
运行
复制
TypeError: can't pickle coroutine objects

之所以会发生这种情况,是因为PyMemoize内部试图将协程存储在Redis中。为此,它使用shelve.Shelf,而后者又使用pickle。问题是,由于未知的原因,pickle不支持酸洗协程。

我尝试过用dill处理协程,并且成功了。如何告诉shelve使用dill作为序列化后端?

我尝试过修补shelve,但它不起作用(我不知道为什么):

代码语言:javascript
运行
复制
import shelve
from dill import Pickler, Unpickler
shelve.Pickler = Pickler
shelve.Unpickler = Unpickler
EN

回答 1

Stack Overflow用户

发布于 2019-07-15 17:22:35

您可以将函数与收益率一起保存,但不能保存生成器。来自documentation:"dill还不能酸洗这些标准类型: frame、生成器、traceback。“

此代码是有效的(dill版本0.3.0):

代码语言:javascript
运行
复制
import shelve
from dill import Pickler, Unpickler
shelve.Pickler = Pickler
shelve.Unpickler = Unpickler
d=shelve.open("shelve.dat")
d['1']=Ellipsis
d.close()

但是如果没有dill,我们就会得到"TypeError: can't pickle ellipsis“:

代码语言:javascript
运行
复制
import shelve
d=shelve.open("shelve.dat")
d['1']=Ellipsis
d.close()
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52927236

复制
相关文章

相似问题

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