将接受类成员函数作为变量的函数传递给python multiprocess pool.map()
发布时间:2020-11-18 03:10:14 所属栏目:Python 来源:互联网
导读:嗨,我一直在为这个早上的大部分时间而苦苦挣扎,希望有人能指出我正确的方向. 这是我目前的代码: def f(tup): return some_complex_function(*tup)def main(): pool = Pool(processes=4) #import and process data omitted _args = [(x.som
|
嗨,我一直在为这个早上的大部分时间而苦苦挣扎,希望有人能指出我正确的方向. 这是我目前的代码: def f(tup):
return some_complex_function(*tup)
def main():
pool = Pool(processes=4)
#import and process data omitted
_args = [(x.some_func1,.05,x.some_func2) for x in list_of_some_class]
results = pool.map(f,_args)
print results
我得到的第一个错误是: > Exception in thread Thread-2: Traceback (most recent call last): > File "/usr/lib/python2.7/threading.py",line 551,in __bootstrap_inner > self.run() File "/usr/lib/python2.7/threading.py",line 504,in run > self.__target(*self.__args,**self.__kwargs) File "/usr/lib/python2.7/multiprocessing/pool.py",line 319,in > _handle_tasks > put(task) PicklingError: Can't pickle <type 'instancemethod'>: attribute lookup __builtin__.instancemethod failed 任何帮助将非常感激. 解决方法多进程模块使用pickle模块序列化传递给函数(f)的参数,该函数在另一个进程中执行.许多内置类型都可以进行pickle,但实例方法无法进行pickle.所以.05很好,但x.some_func1不是.有关详细信息,请参见What can be pickled and unpickled?. 没有简单的解决方案.您需要重构程序,因此实例方法不需要作为参数传递(或避免使用多进程). (编辑:长春站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- python学习笔记四:lambda表达式和switch
- 有没有办法从当前正在执行的python程序逐行输出管道?
- python – 有没有一种简单的方法来添加边框到Kivy Labels,B
- python – 使用Numpy stride_tricks获取非重叠的数组块
- 在python中公开C函数并在C中嵌入python
- python – hashlib.md5()TypeError:Unicode对象必须在散列
- Python:在同一个实例上多次调用__init __()
- python – Pandas Dataframe查找所有列等于的行
- python – 管理站点中的默认过滤器
- python – 如何在我的课堂上赋予字符串?
