Python: как перенаправить вывод с помощью подпроцесса?

что я делаю в командной строке:

cat file1 file2 file3 > myfile

что я хочу сделать с python:

import subprocess, shlex
my_cmd = 'cat file1 file2 file3 > myfile'
args = shlex.split(my_cmd)
subprocess.call(args) # spits the output in the window i call my python program

5 ответов


обновление: ОС.система не рекомендуется, хотя все еще доступна в Python 3.


использовать os.system:

os.system(my_cmd)

если вы действительно хотите использовать подпроцесс, вот решение (в основном сняты из документации подпроцесса):

p = subprocess.Popen(my_cmd, shell=True)
os.waitpid(p.pid, 0)

OTOH, вы можете полностью избежать системных вызовов:

import shutil

with open('myfile', 'w') as outfile:
    for infile in ('file1', 'file2', 'file3'):
        shutil.copyfileobj(open(infile), outfile)

чтобы ответить на ваш исходный вопрос, чтобы перенаправить вывод, просто передать открытый дескриптор файла до subprocess.call:

# Use a list of args instead of a string
input_files = ['file1', 'file2', 'file3']
my_cmd = ['cat'] + input_files
with open('myfile', "w") as outfile:
    subprocess.call(my_cmd, stdout=outfile)

но, как указывали другие, использование внешней команды, такой как cat для этой цели совершенно посторонних.


@PoltoS я хочу присоединиться к некоторым файлам, а затем обработать полученный файл. Я думал, что использование cat было самой простой альтернативой. Есть ли более подходящие для Python способ сделать это?

конечно:

with open('myfile', 'w') as outfile:
    for infilename in ['file1', 'file2', 'file3']:
        with open(infilename) as infile:
            outfile.write(infile.read())

один интересный случай-обновить файл, добавив к нему аналогичный файл. Тогда не нужно будет создавать новый файл в процессе. Это особенно полезно в том случае, когда необходимо добавить большой файл. Вот одна из возможностей использования командной строки teminal непосредственно из python.

import subprocess32 as sub

with open("A.csv","a") as f:
    f.flush()
    sub.Popen(["cat","temp.csv"],stdout=f)

size = 'ffprobe -v error -show_entries format=size -of default=noprint_wrappers=1:nokey=1 dump.mp4 > file'
proc = subprocess.Popen(shlex.split(size), shell=True)
time.sleep(1)
proc.terminate() #proc.kill() modify it by a suggestion
size = ""
with open('file', 'r') as infile:
    for line in infile.readlines():
        size += line.strip()

print(size)
os.remove('file')

при использовании подпроцесс процесс должен быть убит.Это пример.Если вы не убьете процесс, будет пустым, и вы ничего не сможете прочитать.Он может работать на окна.Я не могу убедиться, что он может работать на Unix.