栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

具有池/队列的Python多个子进程在一个完成时立即恢复输出并在队列中启动下一个作业

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

具有池/队列的Python多个子进程在一个完成时立即恢复输出并在队列中启动下一个作业

ThreadPool
可能非常适合您的问题,您可以设置工作线程的数量并添加作业,然后线程将在所有任务中正常工作。

from multiprocessing.pool import ThreadPoolimport subprocessdef work(sample):    my_tool_subprocess = subprocess.Popen('mytool {}'.format(sample),shell=True, stdout=subprocess.PIPE)    line = True    while line:        myline = my_tool_subprocess.stdout.readline()        #here I parse stdout..num = None  # set to the number of workers you want (it defaults to the cpu count of your machine)tp = ThreadPool(num)for sample in all_samples:    tp.apply_async(work, (sample,))tp.close()tp.join()


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/429221.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号