【发布时间】:2017-12-02 12:08:52
【问题描述】:
from multiprocessing import Pool
def f(arg):
if arg == 1:
raise Exception("exception")
return "hello %s" % arg
p = Pool(4)
res = p.map_async(f,(1,2,3,4))
p.close()
p.join()
res.get()
考虑这个人为的例子,我正在创建一个由 4 个工作人员组成的进程池并在 f() 中分配工作。我的问题是:
如何检索为参数 2、3、4 完成的成功工作(同时对参数 1 进行异常处理)?
就像代码给我的一样:
Traceback (most recent call last):
File "process_test.py", line 13, in <module>
res.get()
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/multiprocessing/pool.py", line 567, in get
raise self._value
Exception: exception
【问题讨论】:
标签: python-2.7 process parallel-processing multiprocessing pool