Comment appeler un programme externe en python et récupérer la sortie et code de retour?

Comment puis-je appeler un programme externe avec un script python et récupérer le code de sortie et de retour?

37
demandé sur cfischer 2009-04-01 23:25:10

5 réponses

regardez le module sous-processus : un exemple simple suit...

from subprocess import Popen, PIPE

process = Popen(["ls", "-la", "."], stdout=PIPE)
(output, err) = process.communicate()
exit_code = process.wait()
53
répondu jkp 2015-11-10 18:10:06

suite au commentaire précédent D'Ambroz Bizjak, voici une solution qui a fonctionné pour moi:

import shlex
from subprocess import Popen, PIPE

cmd = "..."
process = Popen(shlex.split(cmd), stdout=PIPE)
process.communicate()
exit_code = process.wait()
13
répondu Jabba 2013-03-03 20:00:32

j'ai développé une petite bibliothèque ( PY-execute ) qui vous permet d'exécuter des programmes externes, récupérer la sortie et le retcode et, en même temps obtenir la sortie en console en temps réel:

>>> from py_execute.process_executor import execute
>>> ret = execute('echo "Hello"')
Hello
>>> ret
(0, 'Hello\n')

vous pouvez éviter d'imprimer sur la console en passant un pseudo user_io:

>>> from mock import Mock
>>> execute('echo "Hello"', ui=Mock())
(0, 'Hello\n')

Je l'ai écrit car avec un Popen simple (en Python 2.7) j'avais du mal à exécuter des commandes avec une longue sortie

3
répondu hithwen 2014-08-11 08:19:53

vérifiez le module de sous-processus ici: http://docs.python.org/library/subprocess.html#module-subprocess . Il devrait obtenir ce que vous devez faire.

2
répondu David Ackerman 2009-04-01 19:30:23

Après quelques recherches, j'ai le code suivant qui fonctionne très bien pour moi. Il imprime à la fois stdout et stderr en temps réel. Espérons que cela aide quelqu'un d'autre qui en a besoin.

stdout_result = 1
stderr_result = 1


def stdout_thread(pipe):
    global stdout_result
    while True:
        out = pipe.stdout.read(1)
        stdout_result = pipe.poll()
        if out == '' and stdout_result is not None:
            break

        if out != '':
            sys.stdout.write(out)
            sys.stdout.flush()


def stderr_thread(pipe):
    global stderr_result
    while True:
        err = pipe.stderr.read(1)
        stderr_result = pipe.poll()
        if err == '' and stderr_result is not None:
            break

        if err != '':
            sys.stdout.write(err)
            sys.stdout.flush()


def exec_command(command, cwd=None):
    if cwd is not None:
        print '[' + ' '.join(command) + '] in ' + cwd
    else:
        print '[' + ' '.join(command) + ']'

    p = subprocess.Popen(
        command, stdout=subprocess.PIPE, stderr=subprocess.PIPE, cwd=cwd
    )

    out_thread = threading.Thread(name='stdout_thread', target=stdout_thread, args=(p,))
    err_thread = threading.Thread(name='stderr_thread', target=stderr_thread, args=(p,))

    err_thread.start()
    out_thread.start()

    out_thread.join()
    err_thread.join()

    return stdout_result + stderr_result
2
répondu Jake W 2014-03-14 02:57:53