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

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

Susan Sarandon
リリース: 2024-12-03 21:58:15
オリジナル
126 人が閲覧しました

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 サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート