在使用python執行Ant構建時遇到的問題: python
使用os.system()調用Ant構建時,不論構建成功仍是失敗(BUILD SUCCESSFUL/BUILD FAILED),命令行的老是正常退出
要解決問題:
首先想到的是獲取ant命令的返回值,根據返回值來決定命令行的退出狀態(0或非0,0表明正常退出)
查閱相關資料,得知python調用系統命令的函數有:os.system、os.popen、commands.getstatusoutput/getstatus/getoutput、subprocess.Popen等。 web
- 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 os
BUILD_SUCCESSFUL = "BUILD SUCCESSFUL"
BUILD_FAILED = "BUILD FAILED"
# 調用Ant執行構建,並返回構建結果
#
def build(ant_target, build_file):
ant_cmd = "ant -f {0} {1} 2>&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
return status
if __name__ == "__main__":
# 調用Ant執行構建
build_file = os.getcwd() + "/build.xml"
ant_targets = "init"
if 0 != build(ant_targets, build_file):
exit(1)
參考: ui
- 【Python執行系統命令的方法 os.system(),os.popen(),commands】http://my.oschina.net/renwofei423/blog/17403
- 【python的subprocess模塊用法】http://blog.csdn.net/g457499940/article/details/17068277