概要
Python の subprocess を使うことでシェルコマンドを実行可能だが、実行結果をリアルタイムに標準出力へとパイプする方法(かつエラーハンドリングが正しく行われる方法)がわかりづらいのでメモしておく。
ちなみに subprocess.run
ではリアルタイムなパイプはできなかった。
方法
import subprocess
import sys
import tempfile
def run_shell(cmd):
print(f'cmd: {cmd}')
with subprocess.Popen(cmd, encoding='UTF-8', stdout=subprocess.PIPE, stderr=subprocess.PIPE) as p:
for line in p.stdout:
sys.stdout.write(line)
p.wait()
for line in p.stderr:
sys.stdout.write(line)
print(f'return: {p.returncode}')
if p.returncode:
raise Exception(f'Error! {cmd}')