Python解析命令行讀取參數(shù)之a(chǎn)rgparse模塊
在多個(gè)文件或者不同語(yǔ)言協(xié)同的項(xiàng)目中,python腳本經(jīng)常需要從命令行直接讀取參數(shù)。萬(wàn)能的python就自帶了argprase包 使得這一工作變得簡(jiǎn)單而規(guī)范。PS:optparse包是類似的功能,只不過寫起來(lái)更麻煩一些。
如果腳本很簡(jiǎn)單或臨時(shí)使用,沒有多個(gè)復(fù)雜的參數(shù)選項(xiàng),可以直接利用sys.argv將腳本后的參數(shù)依次讀取(讀進(jìn)來(lái)的默認(rèn)是字符串格式)。比如如下名為test.py的腳本:
import sys print "Input argument is %s" %(sys.argv)
在shell腳本中運(yùn)行python test.py help可以得到Input argument is help的結(jié)果。
1) 一般形式
但是大多數(shù)情況下,腳本很可能需要多個(gè)參數(shù),而且每次參數(shù)的類型用處各不相同,那么這個(gè)時(shí)候在參數(shù)前添加標(biāo)簽表明參數(shù)的類型和用途便十分有用,而利用argparse模塊可以很方便得實(shí)現(xiàn)這一目的。
同樣用名為test.py的腳本舉個(gè)栗子:
import argparse parser = argparse.ArgumentParser(description="your script description") # description參數(shù)可以用于插入描述腳本用途的信息,可以為空 parser.add_argument('--verbose', '-v', action='store_true', help='verbose mode') # 添加--verbose標(biāo)簽,標(biāo)簽別名可以為-v,這里action的意思是當(dāng)讀取的參數(shù)中出現(xiàn)--verbose/-v的時(shí)候 # 參數(shù)字典的verbose建對(duì)應(yīng)的值為True,而help參數(shù)用于描述--verbose參數(shù)的用途或意義。 args = parser.parse_args() # 將變量以標(biāo)簽-值的字典形式存入args字典 if args.verbose: print "Verbose mode on!" else: print "Verbose mode off!"
運(yùn)行python test.py
后面跟了--verbose/-v的時(shí)候會(huì)輸出前者,如果什么都沒有會(huì)輸出后者。如果輸入了--verbose/-v以外的參數(shù)則會(huì)報(bào)錯(cuò):unrecognized arguments
稍微提一下,action參數(shù)表示值賦予鍵的方式,這里用到的是bool類型;如果是'count'表示將--verbose標(biāo)簽出現(xiàn)的次數(shù)作為verbose的值;'append'表示將每次出現(xiàn)的該便簽后的值都存入同一個(gè)數(shù)組再賦值。(嘛,一般后面兩種用的比較少就不多說了)
PS:--help標(biāo)簽在使用argparse模塊時(shí)會(huì)自動(dòng)創(chuàng)建,因此一般情況不需要我們主動(dòng)定義幫助信息。
$ python test.py --help usage: test.py [-h] [--verbose] your script description optional arguments: -h, --help show this help message and exit --verbose, -v verbose mode
2) 必需參數(shù)
這種模式用于確保某些必需的參數(shù)有輸入。
parser.add_argument('--verbose', required=True, type=int)
required標(biāo)簽就是說--verbose參數(shù)是必需的,并且類型為int,輸入別的類型會(huì)報(bào)錯(cuò)。
3)位置參數(shù)(positional arguments)
位置參數(shù)與sys.argv調(diào)用比較像,參數(shù)沒有顯式的--xxx或者-xxx標(biāo)簽,因此調(diào)用屬性也與sys.argv相同。
parser.add_argument('filename') # 輸入的第一個(gè)參數(shù)賦予名為filename的鍵 args = parser.parse_args() print "Read in %s" %(args.filename)
輸入python test.py test.txt
則會(huì)輸出Read in test.txt
此外,可以用nargs參數(shù)來(lái)限定輸入的位置參數(shù)的個(gè)數(shù),默認(rèn)為1。當(dāng)然nargs參數(shù)也可用于普通帶標(biāo)簽的參數(shù)。
parser.add_argument('num', nargs=2, type=int)
表示腳本可以讀入兩個(gè)整數(shù)賦予num鍵(此時(shí)的值為2個(gè)整數(shù)的數(shù)組)。nargs還可以'*'用來(lái)表示如果有該位置參數(shù)輸入的話,之后所有的輸入都將作為該位置參數(shù)的值;‘+'表示讀取至少1個(gè)該位置參數(shù)。'?'表示該位置參數(shù)要么沒有,要么就只要一個(gè)。(PS:跟正則表達(dá)式的符號(hào)用途一致。)比如用:
parser.add_argument('filename') parser.add_argument('num', nargs='*)
就可以運(yùn)行python test.py text.txt 1 2
由于沒有標(biāo)簽,所以用位置參數(shù)的時(shí)候需要比較小心。
4)輸入類型
之前已經(jīng)提到了用type參數(shù)就可以指定輸入的參數(shù)類型。而這個(gè)type類型還可以表示文件操作的類型從而直接進(jìn)行文件的讀寫操作。
parser.add_argument('file', type=argparser.FileType('r')) # 讀取文件 args = parser.parse_args() for line in args.file: print line.strip()
5)參數(shù)默認(rèn)值
一般情況下會(huì)設(shè)置一些默認(rèn)參數(shù)從而不需要每次輸入某些不需要變動(dòng)的參數(shù),利用default參數(shù)即可實(shí)現(xiàn)。
parser.add_argument('filename', default='text.txt')
這個(gè)時(shí)候至直接運(yùn)行python text.py
就能得到Read in text.txt
而不需要輸入文件名了。
6)候選參數(shù)選擇
表示該參數(shù)能接受的值只能來(lái)自某幾個(gè)值候選值中,除此以外會(huì)報(bào)錯(cuò),用choices參數(shù)即可。比如:
parser.add_argument('filename', choices=['test1.txt', 'text2.txt'])
參考:https://mkaz.tech/python-argparse-cookbook.html
https://docs.python.org/2/howto/argparse.html
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python thrift 實(shí)現(xiàn) 單端口多服務(wù)的過程
這篇文章主要介紹了python thrift 實(shí)現(xiàn) 單端口多服務(wù)的過程,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06Python 抓取數(shù)據(jù)存儲(chǔ)到Redis中的操作
這篇文章主要介紹了Python 抓取數(shù)據(jù)存儲(chǔ)到Redis中的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2020-07-07python__new__內(nèi)置靜態(tài)方法使用解析
這篇文章主要介紹了python__new__內(nèi)置靜態(tài)方法使用解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01教你用Python實(shí)現(xiàn)一個(gè)輪盤抽獎(jiǎng)小游戲
Python提供了許多個(gè)圖像開發(fā)界面的庫(kù),比如現(xiàn)在主流的Tkinter,wxPython,pyqt5等,三種各有優(yōu)點(diǎn),也各有缺點(diǎn),下面對(duì)其分別進(jìn)行介紹和對(duì)比,并編寫代碼實(shí)現(xiàn)一個(gè)輪盤轉(zhuǎn)盤抽獎(jiǎng)小游戲.需要的朋友可以參考下2021-05-05Django-xadmin+rule對(duì)象級(jí)權(quán)限的實(shí)現(xiàn)方式
今天小編就為大家分享一篇Django-xadmin+rule對(duì)象級(jí)權(quán)限的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2020-03-03Python+tkinter實(shí)現(xiàn)樹形圖繪制
Treeview是ttk中的樹形表組件,功能十分強(qiáng)大,非常適用于系統(tǒng)路徑的表達(dá),下面我們就來(lái)看看如何利用這一組件實(shí)現(xiàn)樹形圖的繪制吧,有需要的可以參考下2023-09-09python-leetcode求區(qū)間[M,N]內(nèi)的所有素?cái)?shù)的個(gè)數(shù)實(shí)現(xiàn)方式
這篇文章主要介紹了python-leetcode求區(qū)間[M,N]內(nèi)的所有素?cái)?shù)的個(gè)數(shù)實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08Python paramiko 模塊淺談與SSH主要功能模擬解析
這篇文章主要介紹了Python paramiko 模塊詳解與SSH主要功能模擬,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02TensorFlow進(jìn)階學(xué)習(xí)定制模型和訓(xùn)練算法
本文將為你提供關(guān)于 TensorFlow 的中級(jí)知識(shí),你將學(xué)習(xí)如何通過子類化構(gòu)建自定義的神經(jīng)網(wǎng)絡(luò)層,以及如何自定義訓(xùn)練算法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07