我通过子进程调用rtmpdump并尝试将其输出重定向到文件。问题是我根本无法重定向它。
我首先尝试将sys.stdout设置为打开的文件。这适用于ls,但不适用于rtmpdump。我也试过设置sys.stderr只是为了确保它也没有用。
我尝试使用带有命令行参数的“>>文件”,但它似乎无法正常工作。
同样对于记录,由于某种原因,Eclipse打印rtmpdump的输出,即使我使用subprocess.call而不是subprocess.check_output,也无需调用print方法。这是黑魔法!
有什么建议吗?
编辑:这是一些示例代码。
# /!\ note: need to use os.chdir first to get to the folder with rtmpdump!
command = './rtmpdump -r rtmp://oxy.videolectures.net/video/ -y 2007/pascal/bootcamp07_vilanova/keller_mikaela/bootcamp07_keller_bss_01 -a video -s http://media.videolectures.net/jw-player/player.swf -w ffa4f0c469cfbe1f449ec42462e8c3ba16600f5a4b311980bb626893ca81f388 -x 53910 -o test.flv'
split_command = shlex.split(command)
subprocess.call(split_command)
答案 0 :(得分:19)
sys.stdout是python对父输出流的想法。
在任何情况下,您都希望更改子项的输出流。
subprocess.call和subprocess.Popen获取输出流的命名参数。
因此打开要输出的文件,然后将其作为适当的参数传递给子进程。
f = open("outputFile","wb")
subprocess.call(argsArray,stdout=f)
关于使用>>
的讨论建议您使用shell = True,或者认为您正在将参数传递给shell。在任何情况下,最好使用子进程的数组形式,这样可以避免不必要的进程,以及来自shell的任何奇怪现象。
编辑:
所以我下载了RTMPDump并尝试了它,看起来消息出现在stderr上。
因此,使用以下程序,程序输出中不会显示任何内容,并且rtmpdump会在进入stderr.txt文件时记录:
#!/usr/bin/env python
import os
import subprocess
RTMPDUMP="./rtmpdump"
assert os.path.isfile(RTMPDUMP)
command = [RTMPDUMP,'-r','rtmp://oxy.videolectures.net/video/',
'-y','2007/pascal/bootcamp07_vilanova/keller_mikaela/bootcamp07_keller_bss_01',
'-a','video','-s',
'http://media.videolectures.net/jw-player/player.swf',
'-w','ffa4f0c469cfbe1f449ec42462e8c3ba16600f5a4b311980bb626893ca81f388'
,'-x','53910','-o','test.flv']
stdout = open("stdout.txt","wb")
stderr = open("stderr.txt","wb")
subprocess.call(command,stdout=stdout,stderr=stderr)
答案 1 :(得分:1)
请参阅有关从SO
获取子流程输出的链接我想方法是收集输出并直接将其写入文件或提供输出的文件描述符。
这样的事情:
f = open('dump.txt', 'wb')
p = subprocess.Popen(args, stdout=f, stderr=subprocess.STDOUT, shell=True)