# istarmap.py
import multiprocessing.pool as mpp
def istarmap(self, func, iterable, chunksize=1):
"""starmap-version of imap
"""
if self._state != mpp.RUN:
raise ValueError("Pool not running")
if chunksize < 1:
raise ValueError(
"Chunksize must be 1+, not {0:n}".format(
chunksize))
task_batches = mpp.Pool._get_tasks(func, iterable, chunksize)
result = mpp.IMapIterator(self._cache)
self._taskqueue.put(
(
self._guarded_task_generation(result._job,
mpp.starmapstar,
task_batches),
result._set_length
))
return (item for chunk in result for item in chunk)
mpp.Pool.istarmap = istarmap
使用
starmap()
是不可能的,但是可以使用添加Pool.istarmap()
的补丁。它基于imap()
的代码。您只需创建istarmap.py
-文件并导入模块以应用补丁,然后再进行常规的多处理导入。在然后在你的剧本里:
^{pr2}$临时解决方案:重写要与imap并行的方法。在
相关问题 更多 >
编程相关推荐