在使用python執行Ant構建時遇到的問題:
使用os.system()調用Ant構建時,不論構建成功還是失敗(BUILD SUCCESSFUL/BUILD FAILED),命令行的總是正常退出。
要解決問題:
首先想到的是獲取ant命令的返回值,根據返回值來決定命令行的退出狀態(0或非0,0代表正常退出)
查閱相關資料,得知python調用系統命令的函數有:os.system、os.popen、commands.getstatusoutput/getstatus/getoutput、subprocess.Popen等。
沒有執行構建直接退出(退出狀態為: 1,輸出為: 不是內部或外部命令,也不是可運行的程序或批處理文件)
結論:可能是因為Ant命令不是系統命令的緣故。於是查找資料又得知了subprocess的相關函數,如subprocess.call、subprocess.check_call、subprocess.check_output
不論構建成功還是失敗(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)
無需操作系統直接運行 Python 代碼 http://www.linuxidc.com/Linux/2015-05/117357.htm
CentOS上源碼安裝Python3.4 http://www.linuxidc.com/Linux/2015-01/111870.htm
《Python核心編程 第二版》.(Wesley J. Chun ).[高清PDF中文版] http://www.linuxidc.com/Linux/2013-06/85425.htm
《Python開發技術詳解》.( 周偉,宗傑).[高清PDF掃描版+隨書視頻+代碼] http://www.linuxidc.com/Linux/2013-11/92693.htm
Python腳本獲取Linux系統信息 http://www.linuxidc.com/Linux/2013-08/88531.htm
在Ubuntu下用Python搭建桌面算法交易研究環境 http://www.linuxidc.com/Linux/2013-11/92534.htm
Python 語言的發展簡史 http://www.linuxidc.com/Linux/2014-09/107206.htm