サブプロセスの例として:
import subprocess
x = subprocess.check_output(["echo","one","two","three"])
x は出力になります (python3 バイト クラス:x.decode('utf-8')
文字列の場合)
これは stderr を複製しないことに注意してください。stderr も必要な場合は、次のようにすることができます。
x = subprocess.check_output(["bash","-c", 'echo foo; echo bar >&2'],stderr=subprocess.STDOUT)
もちろん、別の出力変数など、stderr をキャプチャする方法は他にもたくさんあります。
直接制御の使用
ただし、何かトリッキーなことをしていて、直接制御する必要がある場合は、以下のコードを調べてください。
import os
rside, wside = os.pipe()
if not os.fork():
# Child
os.close(rside)
# Make stdout go to parent
os.dup2(wside, 1)
# Make stderr go to parent
os.dup2(wside, 2)
# Optionally make stdin come from nowhere
devnull = os.open("/dev/null", os.O_RDONLY)
os.dup2(devnull, 0)
# Execute the desired program
os.execve("/bin/bash",["/bin/bash","-c","echo stdout; echo stderr >&2"],os.environ)
print("Failed to exec program!")
sys.exit(1)
# Parent
os.close(wside)
pyrside = os.fdopen(rside)
for line in pyrside:
print("Child (stdout or stderr) said: <%s>"%line)
# Prevent zombies! Reap the child after exit
pid, status = os.waitpid(-1, 0)
print("Child exited: pid %d returned %d"%(pid,status))
注: @Beginnerの回答にはいくつかの点で欠陥があります: os._exit(0) が含まれていたため、すぐに子が終了し、他のすべてが無意味になりました。質問の主な目標を無意味にする os.execve() はありません。別の質問の目標として、子の stdout/stderr にアクセスする方法はありません。