Python:如何重定向此输出?

时间:2010-10-20 21:42:55

标签: python subprocess

我通过子进程调用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)

2 个答案:

答案 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)