gpt4 book ai didi

python - 一次运行 x 个命令

转载 作者:行者123 更新时间:2023-11-28 22:00:11 25 4
gpt4 key购买 nike

我必须在 200 个文件上循环运行一个程序。

现在我让它们像这样运行:

for combo in it.combinations(files, 2):
cmd = ["command", combo[0], combo[1]]
subprocess.Popen(cmd)

我想一次只运行 60 个,以免计算机不堪重负,该命令非常占用处理器资源。在 60 个进程正在运行时暂停循环,然后在一个进程完成后再次开始循环以便始终有 60 个进程在运行的最佳方法是什么?

最佳答案

#!/usr/bin/env python
import itertools
import subprocess
from multiprocessing.dummy import Pool # use threads

def run(combo):
cmd = ["command", combo[0], combo[1]]
return combo, subprocess.call(cmd)

def main():
p = Pool(60) # 60 subprocesses at a time
for combo, rc in p.imap_unordered(run, itertools.combinations(files, 2)):
print("%s exited with %s" % (combo, rc))
p.close()
p.join()

if __name__ == "__main__":
main()

This answer demonstrates various techniques to limit number of concurrent subprocesses : 它展示了基于 multiprocessing.Pool、concurrent.futures、threading + Queue 的解决方案。

关于python - 一次运行 x 个命令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15341987/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com