首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用dill / pickle进行pickle时出现TypeError("can't pickle re.Match objects")错误

使用dill / pickle进行pickle时出现TypeError("can't pickle re.Match objects")错误
EN

Stack Overflow用户
提问于 2020-05-18 20:23:58
回答 1查看 541关注 0票数 0

我似乎想不出一种方法来腌制这个,有人能帮上忙吗?这是因为reduce函数是为re.match编写的。

代码:

代码语言:javascript
复制
import re
x = re.match('abcd', 'abcd')
print(type(x))
print(x.__reduce_ex__(3))

输出:

代码语言:javascript
复制
<class 're.Match'>
Traceback (most recent call last):
  File "an.py", line 4, in <module>
    print(x.__reduce_ex__(3))
TypeError: can't pickle re.Match objects

我的确切问题是,在提交一个字符串进行解析之后,我试图对lex / yacc解析器实现类的一个对象进行pickle。

如果我试图在不通过它解析任何字符串的情况下对类对象进行pickle,它就能够进行pickle。只有在我使用它解析一个字符串,然后尝试pickle类对象之后,才会出现问题。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-06-17 18:48:21

Match对象没有__getstate__和__setstate__,因此无法进行pickled,因此无法对整个迭代器进行pickled。

有关此主题的更多信息可在此处找到:https://docs.python.org/3/library/pickle.html#pickle-picklable

下面是对所需对象的进一步解释:https://docs.python.org/3/library/re.html#match-objects

另一种解决方案是实现__getstate__和__setstate__来帮助酸洗过程,这将需要您创建自定义类并实现此函数,对于这种情况,这似乎过于复杂

希望这能有所帮助

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

https://stackoverflow.com/questions/61869528

复制
相关文章

相似问题

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