показывает прогресс при порождении и запуске подпроцесса - PullRequest
0 голосов
/ 25 марта 2011

Мне нужно показать какой-нибудь индикатор выполнения или что-то подобное при порождении и запуске подпроцесса. Как я могу сделать это с Python?

import subprocess

cmd = ['python','wait.py']
p = subprocess.Popen(cmd, bufsize=1024,stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
p.stdin.close()
outputmessage = p.stdout.read() #This will print the standard output from the spawned process
message = p.stderr.read()

Я мог бы создать подпроцесс с этим кодом, но мне нужно что-то распечатать, когда проходит каждая секунда.

Ответы [ 2 ]

5 голосов
/ 25 марта 2011

Поскольку вызов подпроцесса блокируется, одним из способов распечатать что-либо во время ожидания будет использование многопоточности. Вот пример использования threading._Timer:

import threading
import subprocess

class RepeatingTimer(threading._Timer):
    def run(self):
        while True:
            self.finished.wait(self.interval)
            if self.finished.is_set():
                return
            else:
                self.function(*self.args, **self.kwargs)


def status():
    print "I'm alive"
timer = RepeatingTimer(1.0, status)
timer.daemon = True # Allows program to exit if only the thread is alive
timer.start()

proc = subprocess.Popen([ '/bin/sleep', "5" ])
proc.wait()

timer.cancel()

В несвязанной заметке вызов stdout.read () при использовании нескольких каналов может привести к тупику. Вместо этого следует использовать функцию subprocess.communicate ().

0 голосов
/ 25 марта 2011

Насколько я вижу, все, что вам нужно сделать, это поместить эти чтения в цикл с задержкой и печатью - это должно быть точно секунда или около секунды?

...