Python Parser的用法
argparse 模塊可以讓人輕松編寫用戶友好的命令行接口。程序定義它需要的參數(shù),然后 argparse 將弄清如何從 sys.argv 解析出那些參數(shù)。 argparse 模塊還會自動生成幫助和使用手冊,并在用戶給程序傳入無效參數(shù)時報出錯誤信息。
二、示例import argparseparser = 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)’’’False7210000’’’三、步驟1. 實例化ArgumentParser
# 實例化# 創(chuàng)建一個 ArgumentParser 對象# ArgumentParser 對象包含將命令行解析成 Python 數(shù)據(jù)類型所需的全部信息。parser = argparse.ArgumentParser(description = ’test’)
描述description
大多數(shù)對 ArgumentParser 構(gòu)造方法的調(diào)用都會使用 description= 關(guān)鍵字參數(shù)。這個參數(shù)簡要描述這個程度做什么以及怎么做。在幫助消息中,這個描述會顯示在命令行用法字符串和各種參數(shù)的幫助消息之間。
2. 使用add_argument函數(shù)添加參數(shù)這些調(diào)用指定 ArgumentParser 如何獲取命令行字符串并將其轉(zhuǎn)換為對象。
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])
每個參數(shù)解釋如下:
name or flags — 選項字符串的名字或者列表,例如 foo 或者 -f, --foo。
action— 命令行遇到參數(shù)時的動作,默認(rèn)值是 store。
store_const—表示賦值為const;
append—將遇到的值存儲成列表,也就是如果參數(shù)重復(fù)則會保存多個值;
append_const—將參數(shù)規(guī)范中定義的一個值保存到一個列表;
count—存儲遇到的次數(shù);此外,也可以繼承 argparse.Action 自定義參數(shù)解析;
nargs — 應(yīng)該讀取的命令行參數(shù)個數(shù),可以是具體的數(shù)字,或者是?號,當(dāng)不指定值時對于 Positional argument 使用 default—對于 Optional argument 使用 const;或者是 * 號,表示 0 或多個參數(shù);或者是 + 號表示 1 或多個參數(shù)。
const - action 和 nargs 所需要的常量值。
default— 不指定參數(shù)時的默認(rèn)值。
type — 命令行參數(shù)應(yīng)該被轉(zhuǎn)換成的類型。
choices — 參數(shù)可允許的值的一個容器。
required — 可選參數(shù)是否可以省略 (僅針對可選參數(shù))。
help — 參數(shù)的幫助信息,當(dāng)指定為 argparse.SUPPRESS 時表示不顯示該參數(shù)的幫助信息.
metavar — 在 usage 說明中的參數(shù)名稱,對于必選參數(shù)默認(rèn)就是參數(shù)名稱,對于可選參數(shù)默認(rèn)是全大寫的參數(shù)名稱.
dest — 解析后的參數(shù)名稱,默認(rèn)情況下,對于可選參數(shù)選取最長的名稱,中劃線轉(zhuǎn)換為下劃線.
四、使用parse_args解析參數(shù)ArgumentParser 通過 parse_args() 方法解析參數(shù)。它將檢查命令行,把每個參數(shù)轉(zhuǎn)換為適當(dāng)?shù)念愋腿缓笳{(diào)用相應(yīng)的操作。在大多數(shù)情況下,這意味著一個簡單的 Namespace 對象將從命令行解析出的屬性構(gòu)建:
# 解析參數(shù)args = parser.parse_args()print (args.echo)
到此這篇關(guān)于Python Parser的用法的文章就介紹到這了,更多相關(guān)Parser的用法內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. React+umi+typeScript創(chuàng)建項目的過程2. ASP中常用的22個FSO文件操作函數(shù)整理3. ASP編碼必備的8條原則4. ASP調(diào)用WebService轉(zhuǎn)化成JSON數(shù)據(jù),附j(luò)son.min.asp5. 三個不常見的 HTML5 實用新特性簡介6. Warning: require(): open_basedir restriction in effect,目錄配置open_basedir報錯問題分析7. SharePoint Server 2019新特性介紹8. 無線標(biāo)記語言(WML)基礎(chǔ)之WMLScript 基礎(chǔ)第1/2頁9. ASP.NET Core 5.0中的Host.CreateDefaultBuilder執(zhí)行過程解析10. php測試程序運行速度和頁面執(zhí)行速度的代碼
