Echtzeitausgabe von Unterprozessen
In Python bietet das Unterprozessmodul eine bequeme Möglichkeit, externe Programme auszuführen. Standardmäßig erfasst es jedoch die gesamte Ausgabe des Programms und gibt sie zurück, sobald der Vorgang abgeschlossen ist. Dies kann bei lang laufenden Prozessen problematisch sein.
Einführung der iterativen Ausgabeabfrage
Um dieses Problem zu beheben, können Sie die Funktion iter() nutzen, um die Ausgabe Zeile für Zeile abzurufen wie der Befehl es generiert. Hier ist eine modifizierte Version Ihrer Funktion „execute()“, die diesen Ansatz implementiert:
<code class="python">def execute(cmd): popen = subprocess.Popen(cmd, stdout=subprocess.PIPE, universal_newlines=True) for stdout_line in iter(popen.stdout.readline, ""): yield stdout_line popen.stdout.close() return_code = popen.wait() if return_code: raise subprocess.CalledProcessError(return_code, cmd)</code>
Verwendungsbeispiel
Sie können jetzt die Ausgabe des Prozesses so durchlaufen, wie sie ist wird verfügbar:
<code class="python">for path in execute(["locate", "a"]): print(path, end="")</code>
In diesem Beispiel wird die Ausgabe des Befehls „locate a“ kontinuierlich gedruckt, während nach Dateien gesucht wird.
Abfrageintervall
Während diese Methode eine Echtzeitausgabe liefert, kann sich das Abfrageintervall auf die Leistung auswirken. Der Parameter universal_newlines stellt sicher, dass Sie Textzeilen anstelle von Bytes erhalten, was einen zusätzlichen Overhead verursacht. Um die Abfrage zu optimieren, können Sie die Häufigkeit reduzieren, mit der die Ausgabe des Prozesses überprüft wird.
Das obige ist der detaillierte Inhalt vonWie erhalte ich eine Echtzeitausgabe von Unterprozessen in Python?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!