Python調用Ant構建時根據構建狀態來決定命令行退出狀態

在使用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

  1. 【Python執行系統命令的方法 os.system(),os.popen(),commands】http://my.oschina.net/renwofei423/blog/17403
  2. 【python的subprocess模塊用法】http://blog.csdn.net/g457499940/article/details/17068277
相關文章
相關標籤/搜索