Várias entradas e saídas no subprocesso python se comunicam
Eu preciso fazer algo comoesta postagem, mas preciso criar um subprocesso que possa receber entrada e fornecer saída muitas vezes. A resposta aceita desse post tem um bom código ...
from subprocess import Popen, PIPE, STDOUT
p = Popen(['grep', 'f'], stdout=PIPE, stdin=PIPE, stderr=STDOUT)
grep_stdout = p.communicate(input=b'one\ntwo\nthree\nfour\nfive\nsix\n')[0]
print(grep_stdout.decode())
# four
# five
... que eu gostaria de continuar assim:
grep_stdout2 = p.communicate(input=b'spam\neggs\nfrench fries\nbacon\nspam\nspam\n')[0]
print(grep_stdout2.decode())
# french fries
Mas, infelizmente, eu recebo o seguinte erro:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/opt/local/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/subprocess.py", line 928, in communicate
raise ValueError("Cannot send input after starting communication")
ValueError: Cannot send input after starting communication
O método proc.stdin.write () não permite coletar saída, se bem entendi. Qual é a maneira mais simples de manter as linhas abertas para entrada / saída em andamento?
Editar: ====================
Parecepexpect
é uma biblioteca útil para o que estou tentando fazer, mas estou tendo problemas para fazê-lo funcionar. Aqui está uma explicação mais completa da minha tarefa real. estou usandohfst
para obter análises gramaticais de palavras individuais (em russo). A seguir, demonstramos seu comportamento em um shell bash:
$ hfst-lookup analyser-gt-desc.hfstol
> слово
слово слово+N+Neu+Inan+Sg+Acc 0.000000
слово слово+N+Neu+Inan+Sg+Nom 0.000000
> сработай
сработай сработать+V+Perf+IV+Imp+Sg2 0.000000
сработай сработать+V+Perf+TV+Imp+Sg2 0.000000
>
Quero que meu script seja capaz de obter as análises de um formulário por vez. Eu tentei código como este, mas não está funcionando.
import pexpect
analyzer = pexpect.spawnu('hfst-lookup analyser-gt-desc.hfstol')
for newWord in ['слово','сработай'] :
print('Trying', newWord, '...')
analyzer.expect('> ')
analyzer.sendline( newWord )
print(analyzer.before)
# trying слово ...
#
# trying сработай ...
# слово
# слово слово+N+Neu+Inan+Sg+Acc 0.000000
# слово слово+N+Neu+Inan+Sg+Nom 0.000000
#
#
Eu obviamente entendi mal o quepexpect.before
faz. Como posso obter a saída para cada palavra, uma de cada vez?