我一直在尝试腌制一个包含对静态类方法的引用的对象。Pickle 失败(例如 on module.MyClass.foo
)说明它不能被腌制,因为module.foo
它不存在。
我提出了以下解决方案,使用包装器对象在调用时定位函数,保存容器类和函数名:
class PicklableStaticMethod(object):
"""Picklable version of a static method.
Typical usage:
class MyClass:
@staticmethod
def doit():
print "done"
# This cannot be pickled:
non_picklable = MyClass.doit
# This can be pickled:
picklable = PicklableStaticMethod(MyClass.doit, MyClass)
"""
def __init__(self, func, parent_class):
self.func_name = func.func_name
self.parent_class = parent_class
def __call__(self, *args, **kwargs):
func = getattr(self.parent_class, self.func_name)
return func(*args, **kwargs)
不过我想知道,有没有更好、更标准的方法来腌制这样的物体?我不想更改全局pickle
进程(copy_reg
例如使用),但以下模式会很棒:class MyClass(object): @picklable_staticmethod def foo(): print "done."
我在这方面的尝试没有成功,特别是因为我无法从foo
函数中提取所有者类。我什至愿意接受明确的规范(例如@picklable_staticmethod(MyClass)
),但我不知道有什么方法可以直接引用MyClass
定义它的类。
任何想法都会很棒!
与那丹