ホームページ >バックエンド開発 >Python チュートリアル >Python でサブプロセスからのライブ出力を同時にキャプチャして表示するにはどうすればよいですか?

Python でサブプロセスからのライブ出力を同時にキャプチャして表示するにはどうすればよいですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-12-03 21:58:15206ブラウズ

How Can I Simultaneously Capture and Display Live Output from a Subprocess in Python?

サブプロセス コマンド出力を保存しながらライブ出力を印刷する

subprocess.Popen を使用してサブプロセスを呼び出すとき、ロギングの目的でその出力を同時に保存し、ライブで表示することができます。

考えられる解決策

オプション1: イテレータの使用

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)

オプション 2: リーダーとライターの使用

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())

オプション 3: カスタム ソリューション

ret_val = subprocess.Popen(run_command,
                            stdout=log_file,
                            stderr=subprocess.PIPE,
                            shell=True)
while not ret_val.poll():
    log_file.flush()

別の端末では、 run:

tail -f log.txt

これらのメソッドを使用すると、サブプロセスの出力をキャプチャしながらライブ表示することができ、ロギングと進行状況の監視の両方を確実に行うことができます。

以上がPython でサブプロセスからのライブ出力を同時にキャプチャして表示するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。