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