繁体   English   中英

如何在'joblib' Python 库中共享变量

[英]How to share a variable in 'joblib' Python library

from joblib import Parallel, delayed

def func(v):
    temp.append(v)
    return

temp = []
Parallel(n_jobs=4)(delayed(func)(v) for v in range(10))
print temp

我想让共享内存变量。 但是temp的值为空[]。 我该怎么做?

对于其他方法,我尝试了 pickle.dump 和 load。 但是有一个锁定问题。 请给我建议!

from joblib import Parallel, delayed

def func(v):
    return v

temp = Parallel(n_jobs=4)(delayed(func)(v) for v in range(10))
print temp

delayed收集返回的输出通过func列表中并在完成返回。

您需要使用multiprocessing.Manager.list ,例如:

from joblib import Parallel, delayed
from multiprocessing import Manager

manager = Manager()
temp = manager.list()

def func(v, temp):
    temp.append(v)
    return

_ = Parallel(n_jobs=4)(delayed(func)(v, temp) for v in range(10))

temp[:] :

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM