サブプロセスによるリアルタイム出力
進行状況インジケーターを備えたラッパー スクリプトを作成しようとすると、ラップされたスクリプトからの出力が失われるという問題が発生しました。 subprocess.Popen を stdout=PIPE で使用しているにもかかわらず、プログラムがバッファリングされました。お気づきのとおり、bufsize を 1 または 0 に設定しても、出力ループを使用しても、問題は解決されませんでした。
解決策: readline を使用する
偶然にも、次の回避策を見つけました。 stdout パイプの readline メソッドを利用します。最初に採用した、積極的にバッファリングする for ループ方法とは異なり、readline で拡張された while True ループは望ましい動作を示します。
<br>while True:<br> line = p.stdout。 readline()<br> ラインでない場合: Break<br> ...<br>
根本的な問題
この問題は、問題 3907 として追跡されている Python の既知のバグに起因します。異常なバッファリングがうまくいっていない
結論
readline メソッドを活用すると、exec* などの時代遅れのテクニックや潜在的に安全ではないテクニックに頼ることなく、サブプロセス経由で起動されたプログラムからのリアルタイム出力を実現できます。 。この回避策は Python バージョン 3.x 以降でも有効であり、前方互換性が確保されています。
以上がPython でサブプロセスからリアルタイム出力を実現するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。