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!