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

Wie kann ich die Ausgabe eines Live-Unterprozesses erfassen und gleichzeitig protokollieren?

Linda Hamilton
Freigeben: 2024-12-02 10:48:15
Original
1024 Leute haben es durchsucht

How to Capture Live Subprocess Output and Log it Simultaneously?

Live-Ausgabe vom Unterprozessbefehl

Um beide Live-Ausgaben zu erfassen und zur Protokollierung zu speichern, verwenden Sie einen dieser Ansätze:

Verwenden eines Iterators

Erstellen Sie einen Iterator, um daraus zu lesen Unterprozess stdout und schreiben Sie gleichzeitig darauf:

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

Verwenden eines Writers und Readers

Übergeben Sie einen Writer an den Subprozess und lesen Sie von einem Reader:

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

Das obige ist der detaillierte Inhalt vonWie kann ich die Ausgabe eines Live-Unterprozesses erfassen und gleichzeitig protokollieren?. 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