python多进程打印输出_Python:从多个子进程异步打印标准输出

这篇博客探讨了在Python 2.7中如何从多个子进程异步打印标准输出,作者遇到的问题是输出似乎是同步的。为了解决这个问题,提出了使用Queue和线程的解决方案,确保在Windows上能够正确地并行处理子进程的输出。示例代码展示了如何通过创建线程和队列来实现这一目标。
摘要由CSDN通过智能技术生成

我正在测试一种从python2.7中的几个子进程输出stdout的方法。我设置的是一个主进程,此时,它生成三个子进程并输出它们的输出。每个子进程都是一个for循环,它随机进入休眠状态,当它醒来时,会显示“休眠X秒”。在

我看到的问题是打印输出似乎是同步的。假设子进程A休眠1秒,子进程B休眠3秒,子进程C休眠10秒。当主进程试图查看子进程C是否有内容时,它会停止整整10秒,尽管其他两个进程可能已经睡着并打印出了一些内容。这是为了模拟一个子进程在比其他两个进程更长的时间内没有任何输出。在

我需要一个在Windows上运行的解决方案。在

我的代码如下:

主_进程.py在import sys

import subprocess

logfile = open('logfile.txt', 'w')

processes = [

subprocess.Popen('python subproc_1.py', stdout=subprocess.PIPE, bufsize=1),

subprocess.Popen('python subproc_2.py', stdout=subprocess.PIPE, bufsize=1),

subprocess.Popen('python subproc_3.py', stdout=subprocess.PIPE, bufsize=1),

]

while True:

line = processes[0].stdout.readline()

if line != '':

sys.stdout.wri

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值