Wenn wir einen Unterprozess mit subprocess.Popen aufrufen, können wir seine Ausgabe gleichzeitig für Protokollierungszwecke speichern und live auf dem anzeigen Terminal.
Option 1: Verwenden Iteratoren
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)
Option 2: Verwendung eines Readers und eines Writers
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())
Option 3: Benutzerdefinierte Lösung
ret_val = subprocess.Popen(run_command, stdout=log_file, stderr=subprocess.PIPE, shell=True) while not ret_val.poll(): log_file.flush()
Führen Sie in einem anderen Terminal Folgendes aus:
tail -f log.txt
Mit diesen Mit diesen Methoden können Sie die Ausgabe von Unterprozessen erfassen und gleichzeitig live anzeigen, wodurch sowohl Protokollierung als auch Fortschrittsüberwachung sichergestellt werden.
Das obige ist der detaillierte Inhalt vonWie kann ich die Live-Ausgabe eines Unterprozesses in Python gleichzeitig erfassen und anzeigen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!