Heim > Backend-Entwicklung > Python-Tutorial > Wie kann ich die Live-Ausgabe eines Unterprozesses in Python gleichzeitig erfassen und anzeigen?

Wie kann ich die Live-Ausgabe eines Unterprozesses in Python gleichzeitig erfassen und anzeigen?

Susan Sarandon
Freigeben: 2024-12-03 21:58:15
Original
118 Leute haben es durchsucht

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

Live-Ausgabe drucken, während die Befehlsausgabe des Unterprozesses gespeichert wird

Wenn wir einen Unterprozess mit subprocess.Popen aufrufen, können wir seine Ausgabe gleichzeitig für Protokollierungszwecke speichern und live auf dem anzeigen Terminal.

Mögliche Lösungen

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)
Nach dem Login kopieren

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())
Nach dem Login kopieren

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()
Nach dem Login kopieren

Führen Sie in einem anderen Terminal Folgendes aus:

tail -f log.txt
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage