您好,登錄后才能下訂單哦!
這篇文章主要介紹了Python中Parser怎么用,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
argparse
模塊可以讓人輕松編寫用戶友好的命令行接口。程序定義它需要的參數(shù),然后 argparse
將弄清如何從 sys.argv
解析出那些參數(shù)。 argparse
模塊還會(huì)自動(dòng)生成幫助和使用手冊(cè),并在用戶給程序傳入無效參數(shù)時(shí)報(bào)出錯(cuò)誤信息。
import argparse parser = argparse.ArgumentParser(description='test') parser.add_argument('--sparse', action='store_true', default=False, help='GAT with sparse version or not.') ''' _StoreTrueAction(option_strings=['--sparse'], dest='sparse', nargs=0, const=True, default=False, type=None, choices=None, help='GAT with sparse version or not.', metavar=None) ''' parser.add_argument('--seed', type=int, default=72, help='Random seed.') ''' _StoreAction(option_strings=['--seed'], dest='seed', nargs=None, const=None, default=72, type=<class 'int'>, choices=None, help='Random seed.', metavar=None) ''' parser.add_argument('--epochs', type=int, default=10000, help='Number of epochs to train.') ''' _StoreAction(option_strings=['--epochs'], dest='epochs', nargs=None, const=None, default=10000, type=<class 'int'>, choices=None, help='Number of epochs to train.', metavar=None) ''' args = parser.parse_args() print(args.sparse) print(args.seed) print(args.epochs) ''' False 72 10000 '''
# 實(shí)例化 # 創(chuàng)建一個(gè) ArgumentParser 對(duì)象 # ArgumentParser 對(duì)象包含將命令行解析成 Python 數(shù)據(jù)類型所需的全部信息。 parser = argparse.ArgumentParser(description = 'test')
描述description
大多數(shù)對(duì) ArgumentParser 構(gòu)造方法的調(diào)用都會(huì)使用 description= 關(guān)鍵字參數(shù)。這個(gè)參數(shù)簡要描述這個(gè)程度做什么以及怎么做。在幫助消息中,這個(gè)描述會(huì)顯示在命令行用法字符串和各種參數(shù)的幫助消息之間。
這些調(diào)用指定 ArgumentParser 如何獲取命令行字符串并將其轉(zhuǎn)換為對(duì)象。
parser.add_argument('--sparse', action='store_true', default=False, help='GAT with sparse version or not.') parser.add_argument('--seed', type=int, default=72, help='Random seed.') parser.add_argument('--epochs', type=int, default=10000, help='Number of epochs to train.')
add_argument() 方法定義如何解析命令行參數(shù)
ArgumentParser.add_argument(name or flags...[, action][, nargs][, const][, default][, type][, choices][, required][, help][, metavar][, dest])
每個(gè)參數(shù)解釋如下:
name or flags
— 選項(xiàng)字符串的名字或者列表,例如 foo 或者 -f, --foo。
action
— 命令行遇到參數(shù)時(shí)的動(dòng)作,默認(rèn)值是 store。
store_const
—表示賦值為const;
append
—將遇到的值存儲(chǔ)成列表,也就是如果參數(shù)重復(fù)則會(huì)保存多個(gè)值;
append_const
—將參數(shù)規(guī)范中定義的一個(gè)值保存到一個(gè)列表;
count
—存儲(chǔ)遇到的次數(shù);此外,也可以繼承 argparse.Action 自定義參數(shù)解析;
nargs
— 應(yīng)該讀取的命令行參數(shù)個(gè)數(shù),可以是具體的數(shù)字,或者是?號(hào),當(dāng)不指定值時(shí)對(duì)于 Positional argument 使用 default
—對(duì)于 Optional argument 使用 const;或者是 * 號(hào),表示 0 或多個(gè)參數(shù);或者是 + 號(hào)表示 1 或多個(gè)參數(shù)。
const - action
和 nargs
所需要的常量值。
default
— 不指定參數(shù)時(shí)的默認(rèn)值。
type
— 命令行參數(shù)應(yīng)該被轉(zhuǎn)換成的類型。
choices
— 參數(shù)可允許的值的一個(gè)容器。
required
— 可選參數(shù)是否可以省略 (僅針對(duì)可選參數(shù))。
help
— 參數(shù)的幫助信息,當(dāng)指定為 argparse.SUPPRESS 時(shí)表示不顯示該參數(shù)的幫助信息.
metavar
— 在 usage 說明中的參數(shù)名稱,對(duì)于必選參數(shù)默認(rèn)就是參數(shù)名稱,對(duì)于可選參數(shù)默認(rèn)是全大寫的參數(shù)名稱.
dest
— 解析后的參數(shù)名稱,默認(rèn)情況下,對(duì)于可選參數(shù)選取最長的名稱,中劃線轉(zhuǎn)換為下劃線.
ArgumentParser 通過 parse_args() 方法解析參數(shù)。它將檢查命令行,把每個(gè)參數(shù)轉(zhuǎn)換為適當(dāng)?shù)念愋腿缓笳{(diào)用相應(yīng)的操作。在大多數(shù)情況下,這意味著一個(gè)簡單的 Namespace 對(duì)象將從命令行解析出的屬性構(gòu)建:
# 解析參數(shù) args = parser.parse_args() print (args.echo)
Python主要應(yīng)用于:1、Web開發(fā);2、數(shù)據(jù)科學(xué)研究;3、網(wǎng)絡(luò)爬蟲;4、嵌入式應(yīng)用開發(fā);5、游戲開發(fā);6、桌面應(yīng)用開發(fā)。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Python中Parser怎么用”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。