亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Python 從subprocess運行的子進程中實時獲取輸出的例子

系統 1754 0

有些時候,我們需要將某些程序放到子進程中去運行,以達到整合系統的目的。在Python中,一個非常好的選擇就是使用subprocess模塊,本模塊為開辟子進程去執行子程序提供了統一的接口,更加便于學習和使用。

同時,對于在子進程里的程序,我們希望能夠實時獲取其輸出,以在主進程中打印相關信息,使我們能夠了解當前子程序的執行進度。對此,subprocess模塊也提供了相應的參數,能夠將子程序的標準輸出和標準錯誤輸出返回給主程序。

下面,我們就通過一個例子來說明這個功能。首先,我們需要一個用于模擬標準輸出和標準錯誤輸出的“子程序”――subprogram.py:

            
import sys
import time
 
 
for i in range(5):
  sys.stdout.write('Processing {}\n'.format(i))
  time.sleep(1)
 
for i in range(5):
  sys.stderr.write('Error {}\n'.format(i))
  time.sleep(1)
          

可以看到這個程序非常簡單,分別向標準輸出和標準錯誤寫入了5條信息,并且輸出之間有1秒的間隔。下面是驅動這個“子程序”運行的“主程序”――main.py:

            
import shlex
import subprocess
 
if __name__ == '__main__':
  shell_cmd = 'python3 subprogram.py'
  cmd = shlex.split(shell_cmd)
  p = subprocess.Popen(cmd, shell=False, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
  while p.poll() is None:
    line = p.stdout.readline()
    line = line.strip()
    if line:
      print('Subprogram output: [{}]'.format(line))
  if p.returncode == 0:
    print('Subprogram success')
  else:
    print('Subprogram failed')
          

可以看到,我們通過指定stderr=subprocess.STDOUT,將子程序的標準錯誤輸出重定向到了標準輸出,以使我們可以直接從標準輸出中同時獲取標準輸出和標準錯誤的信息。運行這個程序,我們會期待main.py會每秒輸出一次信息到控制臺,但是事實上,我們直到等了10秒之后才一次性看到所有的10條輸出。

產生這種現象的原因也非常簡單,就是標準輸出和標準錯誤有一個緩存的概念,它不會立即將程序的標準輸出內容返回,而是會做一定的緩存,直到緩存滿或者程序結束強制清空緩存時才輸出。了解到問題的原因,解決問題的方法也就一目了然了,我們只需要在子程序中,每次輸出后去手動清空一下緩存即可,以下是修改過的subprogram.py:

            
import sys
import time
 
 
for i in range(5):
  sys.stdout.write('Processing {}\n'.format(i))
  sys.stdout.flush()
  time.sleep(1)
 
for i in range(5):
  sys.stderr.write('Error {}\n'.format(i))
  sys.stderr.flush()
  time.sleep(1)
          

經過上述的修改之后,再次運行main.py程序,我們會看到,每秒會輸出一條信息,達到了我們在主程序中,去追蹤子程序執行過程的目的。

PS:測試環境是Python3.6.1 Mac版。

以上這篇Python 從subprocess運行的子進程中實時獲取輸出的例子就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 天天干天天射天天舔 | 免费一级黄色毛片 | 国产精品久久久久天天影视 | 国产伦理久久精品久久久久 | 九一视频在线免费观看 | 国产视频在线观看福利 | 狠狠综合久久综合网站 | 在线观看精品视频一区二区三区 | 欧美一区亚洲 | 97色伦图片97色伦图影院久久 | 成人激情视频在线 | 久久精品无遮挡一级毛片 | 一区二区三区四区产品乱码伦 | 精品国产品国语在线不卡丶 | 亚洲va久久久久综合 | 天海翼一区二区在线观看 | 国产中文字幕在线免费观看 | 亚洲国产精品人久久 | 无码免费一区二区三区免费播放 | 国产精品视频网 | 久久99国产这里有精品视 | 国产成人精品高清免费 | 91热国内精品永久免费观看 | 色综合久久久久综合体桃花网 | 婷婷国产 | 人人爽影院 | 国产亚洲精品麻豆一区二区 | 日韩一区二区三区在线视频 | 九九香蕉网 | 羞羞视频网站 | 久久69 | 精品久久久久久亚洲 | 国产香蕉在线 | 一级黄色毛片免费看 | 亚洲国产精品xo在线观看 | 老司机午夜精品视频在线观看免费 | 中文字幕久精品免费视频蜜桃视频 | 欧美一级特黄毛片免费 | 免费视频网站在线观看黄 | 国产日韩精品一区二区在线观看 | 我色综合 |