Python Subprocess Readlines() 掛起
問題陳述:
嘗試流式傳輸時使用subprocess 模組在Python 中逐行讀取Ruby文件,readlines() 呼叫區塊無限期地阻止進一步執行。
原因:
在非 Linux 作業系統上使用 pty 模組模擬偽終端時,可能會出現此問題。 pty 是 Linux 特定的函式庫,不保證其在其他系統上的行為。
解決方案:
1.使用Pexpect:
Pexpect 是一個跨互動平台庫,專為自動化互動式平台應用程式而設計。它提供了一個用於透過偽終端發送和接收資料的高級介面。
import pexpect pexpect.run("ruby ruby_sleep.rb", logfile=sys.stdout)
2.使用 Stdbuf:
Stdbuf 可用於在非互動模式下啟用行緩衝,允許在每一行上刷新輸出。
proc = Popen(['stdbuf', '-oL', 'ruby', 'ruby_sleep.rb'], bufsize=1, stdout=PIPE, stderr=STDOUT, close_fds=True) for line in iter(proc.stdout.readline, b''): print(line) proc.stdout.close() proc.wait()
3.使用標準庫中的 Pty(適用於 Linux):
import errno import os import pty from subprocess import Popen, STDOUT master_fd, slave_fd = pty.openpty() # provide tty to enable line-buffering on Ruby's side proc = Popen(['ruby', 'ruby_sleep.rb'], stdin=slave_fd, stdout=slave_fd, stderr=STDOUT, close_fds=True) os.close(slave_fd) try: while 1: try: data = os.read(master_fd, 512) except OSError as e: if e.errno != errno.EIO: raise break # EIO means EOF on some systems else: if not data: # EOF break print('got ' + repr(data)) finally: os.close(master_fd) if proc.poll() is None: proc.kill() proc.wait() print("This is reached!")
以上是為什麼 Python 的 `subprocess.readlines()` 在串流 Ruby 輸出時掛起,如何修復它?的詳細內容。更多資訊請關注PHP中文網其他相關文章!