要捕获子进程的实时输出而不阻塞它,可以使用Python的subprocess模块。下面是一个示例代码:
import subprocess
def capture_output(cmd):
# 创建子进程,使用stdout=subprocess.PIPE参数捕获输出
process = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
# 循环读取子进程的输出
while True:
# 逐行读取输出
output = process.stdout.readline().decode().strip()
if output == '' and process.poll() is not None:
break
if output:
print(output) # 在这里可以对输出进行处理,例如写入日志文件等
# 等待子进程结束,并获取返回码
rc = process.poll()
return rc
# 调用示例,执行命令'ping baidu.com'并捕获输出
rc = capture_output(['ping', 'baidu.com'])
print('返回码:', rc)
这段代码中,我们使用subprocess.Popen
创建了一个子进程,并使用stdout=subprocess.PIPE
参数指定捕获子进程的标准输出。然后,我们通过循环读取子进程的输出,并对输出进行处理(在示例中直接打印输出)。最后,我们等待子进程结束,并获取它的返回码。
注意:在循环中使用process.stdout.readline()
读取输出的方式可以实现实时输出,但可能会导致程序阻塞在这一行,直到有新的输出。如果你要同时处理标准输出和标准错误输出,可以将stderr=subprocess.STDOUT
传递给subprocess.Popen
的stderr
参数。
另外,如果你需要同时捕获子进程的输入和输出,可以使用subprocess.Popen
的stdin
参数来指定输入。
上一篇:捕获子进程的日志输出