DOS*_*ter 5 python multithreading multiprocessing keyerror
我有以下代码,其中我尝试调用一个函数compute_cluster,该函数执行一些计算并将结果写入txt文件中(每个进程将其结果分别写入不同的txt文件中),但是,当我运行以下代码时:
def main():
p = Pool(19)
p.map(compute_cluster, [(l, r) for l in range(6, 25) for r in range(1, 4)])
p.close()
if __name__ == "__main__":
main()
Run Code Online (Sandbox Code Playgroud)
它崩溃并显示以下错误:
File "RMSD_calc.py", line 124, in <module>
main()
File "RMSD_calc.py", line 120, in main
p.map(compute_cluster, [(l, r) for l in range(6, 25) for r in range(1, 4)])
File "/usr/local/lib/python2.7/multiprocessing/pool.py", line 225, in map
return self.map_async(func, iterable, chunksize).get()
File "/usr/local/lib/python2.7/multiprocessing/pool.py", line 522, in get
raise self._value
KeyError: 0
Run Code Online (Sandbox Code Playgroud)
当我在网上搜索“ KeyError:0”的含义时,我没有发现任何有用的信息,因此高度赞赏为什么出现此错误的任何建议
KeyError发生在compute_cluster()子进程中并p.map()在父进程中为您重新提出:
from multiprocessing import Pool
def f(args):
d = {}
d[0] # <-- raises KeyError
if __name__=="__main__":
p = Pool()
p.map(f, [None])
Run Code Online (Sandbox Code Playgroud)
Traceback (most recent call last):
File "raise-exception-in-child.py", line 9, in <module>
p.map(f, [None])
File "/usr/lib/python2.7/multiprocessing/pool.py", line 227, in map
return self.map_async(func, iterable, chunksize).get()
File "/usr/lib/python2.7/multiprocessing/pool.py", line 528, in get
raise self._value
KeyError: 0
Run Code Online (Sandbox Code Playgroud)
要查看完整的回溯,请在子进程中捕获异常:
import logging
from multiprocessing import Pool
def f(args):
d = {}
d[0] # <-- raises KeyError
def f_mp(args):
try:
return f(args)
except Exception:
logging.exception("f(%r) failed" % (args,))
if __name__=="__main__":
p = Pool()
p.map(f_mp, [None])
Run Code Online (Sandbox Code Playgroud)
ERROR:root:f(None) failed
Traceback (most recent call last):
File "raise-exception-in-child.py", line 10, in f_mp
return f(args)
File "raise-exception-in-child.py", line 6, in f
d[0] # <-- raises KeyError
KeyError: 0
Run Code Online (Sandbox Code Playgroud)
它表明d[0]导致异常。