python pexpect输出_关于多线程:如何使用pexpect获取python中子进程的自发输出
這與我使用wx.TextCtrl(或底層GTK +)發布的另一個多線程問題有關,在通過從主線程調用GUI交互進行更正后,我發現它再次涉及到管道塊緩沖問題。那么如何從subprocess.stdout獲得自發輸出呢?
簡而言之,當前我正在使用subprocess.popen啟動外部長期運行的程序。
launchcmd=["EXTERNAL_PROGRAM_EXE"]
p = subprocess.Popen(launchcmd, stdin=subprocess.PIPE,
stdout=subprocess.PIPE, stderr=subprocess.PIPE)
self.outputThread = BashProcessThread(p.stdout.readline)
self.outputThread.start()
# wx.TextCtrl is used to make input/output
self.textctrl = wx.TextCtrl(self, style=wx.TE_PROCESS_ENTER|wx.TE_MULTILINE)
我使用一個單獨的線程讀取后臺程序的標準輸出,并使用" wx.CallAfter"進行回調。
class BashProcessThread(threading.Thread):
def __init__(self, readlineFunc, textctrl):
threading.Thread.__init__(self)
self.readlineFunc = readlineFunc
def run(self):
while True:
line = self.readlineFunc()
wx.CallAfter(textctrl.AppendText(line))
上面的代碼打印出子進程日志消息的塊掛起的塊(而不是自發地一行一行),最糟糕的是直到用戶發送下一個輸入之前,其余5-6行的日志消息才被及時打印。
從我的舊文章中,我知道有pty和pexpect,這可能使子流程認為它正在與偽tty交互。但是應該如何使用預期,特別是考慮到后臺進程是長期的,獨立運行的任務呢?
例如,如果我使用
child=pexpect.spawn(launchcmd)
如何獲得子流程的輸出和輸入,因此我可以使用wx.TextCtrl打印輸出,還可以使用wx.TextCtrl將用戶輸入轉發到子流程?
您是否嘗試過類似的方法:
child = pexpect.spawn(launchcmd)
while True:
try:
child.expect('
')
print(child.before)
except pexpect.EOF:
break
我花了30分鐘的時間嘗試生成所有的讀取命令。 甚至從未見過before屬性。 祝您一切順利。
我認為更優雅的解決方案是使用child.logfile屬性。
我發現這兩種方法都能很好地獲得實時輸出。
如果您不希望用戶進行交互,例如在后臺流程中:
child = pexpect.spawn(launchcmd)
child.logfile = sys.stdout
child.expect(pexpect.EOF)
child.close()
如果您不使用后臺進程,并且希望能夠與該程序進行交互(如果它提示您)。 在這里發生的是,您進入了交互模式,并且pexpect直接寫入屏幕。 程序運行結束/ EOF時,將引發OSError。
child = pexpect.spawn(launchcmd)
try:
child.interact()
except OSError:
pass
child.close()
總結
以上是生活随笔為你收集整理的python pexpect输出_关于多线程:如何使用pexpect获取python中子进程的自发输出的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux lib目录找不到,linux
- 下一篇: websocket python爬虫_p