Heim >Backend-Entwicklung >Python-Tutorial >Wie kann ich die Unterprozessausgabe Zeile für Zeile in Python durchlaufen und dabei alle Ausgaben protokollieren?

Wie kann ich die Unterprozessausgabe Zeile für Zeile in Python durchlaufen und dabei alle Ausgaben protokollieren?

Susan Sarandon
Susan SarandonOriginal
2024-12-06 12:08:11839Durchsuche

How Can I Iterate Over Subprocess Output Line by Line in Python While Logging All Output?

Zeilenweise Iteration der Subprozessausgabe

Bei der Verwendung von Subprozessen in Python zum Ausführen externer Befehle kann die Verarbeitung der Ausgabe eine Herausforderung darstellen. Dieser Artikel befasst sich mit einem bestimmten Szenario, in dem ein Skript alle Ausgaben in einer Protokolldatei speichern und gleichzeitig dem Benutzer ausgewählte Zeilen anzeigen muss.

Der ursprüngliche Ansatz wurde für die Zeile in proc.stdout: verwendet, die die gesamte Ausgabe liest sofort vor der Iteration. Um dieses Problem zu lösen, besteht die vorgeschlagene Lösung darin, stattdessen readline() zu verwenden:

while True:
  line = proc.stdout.readline()
  if not line:
    break
  #the real code does filtering here
  print "test:", line.rstrip()

Dieser Ansatz ermöglicht es dem Skript, jede Zeile zu drucken, sobald sie vom Unterprozess empfangen wird, wodurch eine Ausgabefilterung in Echtzeit gewährleistet wird.

Es ist jedoch wichtig zu beachten, dass die Handhabung von Unterprozesspuffern zusätzliche Komplexität mit sich bringen kann. Je nach Python-Version und Betriebssystem kann die vorgeschlagene Lösung zu unterschiedlichen Ergebnissen führen.

Das obige ist der detaillierte Inhalt vonWie kann ich die Unterprozessausgabe Zeile für Zeile in Python durchlaufen und dabei alle Ausgaben protokollieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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