標籤:
在使用python執行Ant構建時遇到的問題:
使用os.system()調用Ant構建時,不論構建成功還是失敗(BUILD SUCCESSFUL/BUILD FAILED),命令列的總是正常退出
要解決問題:
首先想到的是擷取ant命令的傳回值,根據傳回值來決定命令列的退出狀態(0或非0,0代表正常退出)
查閱相關資料,得知python調用系統命令的函數有:os.system、os.popen、commands.getstatusoutput/getstatus/getoutput、subprocess.Popen等。
- os.system()無法獲得傳回值和輸出
- os.popen()返回的是file read的對象,對其進行讀取read()操作可以看到執行的輸出。
- commands.getstatusoutput()返回系統命令的退出狀態和輸出
- commands.getstatus()返回系統命令的退出狀態
- commands.getoutput()返回系統命令的輸出
在使用commands的相關函數執行Ant命令列時:
沒有執行構建直接退出(退出狀態為: 1,輸出為: 不是內部或外部命令,也不是可啟動並執行程式或批次檔)
結論:可能是因為Ant命令不是系統命令的緣故
於是尋找資料又得知了subprocess的相關函數,如subprocess.call、subprocess.check_call、subprocess.check_output
- subprocess.call (*popenargs , **kwargs )執行命令,並等待命令結束,再返回子進程的傳回值
- subprocess.check_call (*popenargs , **kwargs )執行上面的call命令,並檢查傳回值,如果子進程返回非0,則會拋出CalledProcessError異常,這個異常會有個returncode 屬性,記錄子進程的傳回值。
- subprocess.check_output()執行程式,並返回其標準輸出
在使用subprocess.call命令執行Ant命令列時:
不論構建成功還是失敗(BUILD SUCCESSFUL/BUILD FAILED),命令列總是正常退出(傳回值為 0)
結論:命令列退出狀態(即傳回值)與Ant構建狀態無關,只是表示Ant構建是否正常執行完畢的狀態
既然命令列退出狀態(即傳回值)與Ant構建狀態無關,
那麼只有 解析命令列輸出結果,根據構建成功或失敗來決定命令列退出狀態
於是,使用os.popen()命令獲得輸出結果並解析返回狀態值
具體Python指令碼DEMO如下:
#!Python.exe # python version 2.7.8# -*- coding: utf-8 -*-"調用Ant執行構建,並返回構建結果"__author__ = "donhui"import osBUILD_SUCCESSFUL = "BUILD SUCCESSFUL"BUILD_FAILED = "BUILD FAILED"# 調用Ant執行構建,並返回構建結果#def build(ant_target, build_file): ant_cmd = "ant -f {0} {1}".format(build_file, ant_target) logging.info(ant_cmd) status = 1 for line in os.popen(ant_cmd): print line, if BUILD_SUCCESSFUL in line: status = 0 if 1 == status: print BUILD_FAILED, return statusif __name__ == "__main__": # 調用Ant執行構建 build_file = os.getcwd() + "/build.xml" ant_targets = "init" if 0 != build(ant_targets, build_file): exit(1)
參考:
- 【Python執行系統命令的方法 os.system(),os.popen(),commands】http://my.oschina.net/renwofei423/blog/17403
- 【python的subprocess模組用法】http://blog.csdn.net/g457499940/article/details/17068277
python調用Ant構建時根據構建狀態來決定命令列退出狀態