首页 > 后端开发 > Python教程 > 如何捕获实时子流程输出并同时记录它?

如何捕获实时子流程输出并同时记录它?

Linda Hamilton
发布: 2024-12-02 10:48:15
原创
1025 人浏览过

How to Capture Live Subprocess Output and Log it Simultaneously?

子进程命令的实时输出

要捕获实时输出并将其存储以进行记录,请采用以下方法之一:

使用迭代器

创建迭代器从子进程标准输出读取并同时写入:

import subprocess
import sys

with open("test.log", "wb") as f:
    process = subprocess.Popen(your_command, stdout=subprocess.PIPE)
    for c in iter(lambda: process.stdout.read(1), b""):
        sys.stdout.buffer.write(c)
        f.buffer.write(c)
登录后复制

使用写入器和读取器

将写入器传递给子进程并从读取器读取:

import io
import time
import subprocess
import sys

filename = "test.log"
with io.open(filename, "wb") as writer, io.open(filename, "rb", 1) as reader:
    process = subprocess.Popen(command, stdout=writer)
    while process.poll() is None:
        sys.stdout.write(reader.read())
        time.sleep(0.5)
    # Read the remaining
    sys.stdout.write(reader.read())
登录后复制

以上是如何捕获实时子流程输出并同时记录它?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板