[解決済み] サブプロセスによるリアルタイム出力の取得
2022-04-27 23:38:55
質問
コマンドライン・プログラム(svnadmin verify)のラッパースクリプトを書いて、操作の進捗状況をうまく表示しようとしています。 そのためには、ラップされたプログラムから出力される各行を、出力されると同時に見ることができる必要があります。
を使ってプログラムを実行すればいいんだと思ったんだ。
subprocess.Popen
を使用します。
stdout=PIPE
そして、各行を読み込んで、それに応じて行動します。 しかし、次のコードを実行すると、出力はどこかでバッファリングされているようで、1行目から332行目、そして333行目から439行目(出力の最終行)という2つのチャンクに分かれて表示されるようになりました。
from subprocess import Popen, PIPE, STDOUT
p = Popen('svnadmin verify /var/svn/repos/config', stdout = PIPE,
stderr = STDOUT, shell = True)
for line in p.stdout:
print line.replace('\n', '')
サブプロセスのドキュメントを少し見た後、私は
bufsize
パラメータを
Popen
ということで、bufsizeを1(行ごとにバッファする)と0(バッファしない)に設定してみましたが、どちらの値でも行の配信方法は変わらないようです。
この時点で藁にもすがる思いで、次のような出力ループを書きました。
while True:
try:
print p.stdout.next().replace('\n', '')
except StopIteration:
break
が、同じ結果になりました。
サブプロセスを使って実行されたプログラムの出力を「リアルタイム」に取得することは可能でしょうか? Pythonに前方互換性のある他のオプションはありますか(
exec*
)?
解決方法は?
これを試したのですが、なぜかコード中に
for line in p.stdout:
...
は積極的にバッファリングし、バリアント
while True:
line = p.stdout.readline()
if not line: break
...
を実行しない。どうやらこれは既知のバグのようです。 http://bugs.python.org/issue3907 (この問題は2018年8月29日現在、"Closed"となっています)
関連
-
Pythonの学習とデータマイニングのために知っておくべきターミナルコマンドのトップ10
-
[解決済み】TypeErrorの修正方法。Unicodeオブジェクトは、ハッシュ化する前にエンコードする必要がある?
-
[解決済み】ilocが「IndexError: single positional indexer is out-of-bounds」を出す。
-
[解決済み】IndexError: invalid index to scalar variableを修正する方法
-
[解決済み】Python: OverflowError: 数学の範囲エラー
-
[解決済み] 関数内でグローバル変数を使用する
-
[解決済み] モジュールの関数名(文字列)を使って、モジュールの関数を呼び出す。
-
[解決済み] インスタンスのクラス名を取得する?
-
[解決済み] シェルコマンドの実行と出力のキャプチャ
-
[解決済み】forループを使った辞書の反復処理
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】TypeError: unhashable type: 'numpy.ndarray'.
-
[解決済み】TypeErrorの修正方法。Unicodeオブジェクトは、ハッシュ化する前にエンコードする必要がある?
-
[解決済み】numpyの配列連結。"ValueError:すべての入力配列は同じ次元数でなければならない"
-
[解決済み】syntaxError: 'continue' がループ内で適切に使用されていない
-
[解決済み] 'int'オブジェクトに'__getitem__'属性がない。
-
[解決済み】 AttributeError("'str' object has no attribute 'read'")
-
[解決済み] TypeError: 'DataFrame' オブジェクトは呼び出し可能ではない
-
[解決済み】ImportError: bs4という名前のモジュールがない(BeautifulSoup)
-
[解決済み】ValueError: pickleプロトコルがサポートされていません。3、python2 pickleはpython3 pickleでダンプしたファイルを読み込むことができない?
-
[解決済み】Flaskのテンプレートが見つからない【重複あり