У меня есть две программы python (одна из них - подпроцесс), которые должны взаимодействовать друг с другом. В настоящее время я делаю это через stdin
и stdout
. Однако запись в подпроцесс stdin
кажется очень медленной.
a.py
, программа, которая принимает произвольную строку ввода и печатает время:
from time import time, sleep
from sys import stdout, stdin
while True:
stdin.readline()
stdout.write('%f\n' % time())
stdout.flush()
b.py
, программа, которая запускает a.py
, и время, необходимое для записи в программу stdin
и считанного с нее stdout
:
from time import time
from subprocess import PIPE, Popen
from threading import Thread
stdin_times = []
stdout_times = []
p = Popen(['python', 'a.py'], stdin=PIPE, stdout=PIPE)
for i in range(100000):
t1 = time()
p.stdin.write(b'\n')
p.stdin.flush()
t2 = float(p.stdout.readline().strip().decode())
t3 = time()
stdin_times.append(t2 - t1)
stdout_times.append(t3 - t2)
p.kill()
print('stdin (min/ave):', min(stdin_times), sum(stdin_times) / len(stdin_times))
print('stdout (min/ave):', min(stdout_times), sum(stdout_times) / len(stdout_times))
Пример вывода:
stdin (min/ave): 1.69277191162e-05 0.000138891274929
stdout (min/ave): 1.78813934326e-05 2.09228754044e-05
Я использую Python 3.1.2 на Ubuntu 10.10.
Почему запись на a.py
stdin
намного медленнее, чем чтение из stdout
?
Есть ли в любом случае, я могу заставить эти две программы быстрее общаться?