天天看點

python中argument什麼意思_python add_argument() 的使用方法

介紹:

argparse

argparse 是 Python 内置的一個用于指令項選項與參數解析的子產品,通過在程式中定義好我們需要的參數,argparse 将會從 sys.argv 中解析出這些參數,并自動生成幫助和使用資訊。當然,Python 也有第三方的庫可用于指令行解析,而且功能也更加強大,比如 docopt,Click。

argparse 使用

簡單示例

我們先來看一個簡單示例。主要有三個步驟:

建立 ArgumentParser() 對象

調用 add_argument() 方法添加參數

使用 parse_args() 解析添加的參數

現在我們來簡單的測試一下:

import argparse

parser = argparse.ArgumentParser()

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.‘)

args = parser.parse_args()

print(args.sparse)

print(args.seed)

print(args.epochs)

列印内容如下:

/home/user/anaconda3/bin/python3.6 /home/user/lly/pyGAT-master/test.py

False

72

10000

Process finished with exit code 0

舉例:

parser = argparse.ArgumentParser()

parser.add_argument(‘--sparse‘, action=‘store_true‘, 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.‘)

args = parser.parse_args()

print(args.sparse)

print(args.seed)

print(args.epochs)

列印如下:

False

72

10000

舉例

import argparse

parser = argparse.ArgumentParser()

parser.add_argument(‘--sparse‘, action=‘store_true‘, default=True, 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.‘)

args = parser.parse_args()

print(args.sparse)

print(args.seed)

print(args.epochs)

列印如下:

True

72

10000

先奉上add_argument() 方法定義如何解析指令行參數:

ArgumentParser.add_argument(name or flags...[, action][, nargs][, const][, default][, type][, choices][, required][, help][, metavar][, dest])

每個參數解釋如下:

name or flags - 選項字元串的名字或者清單,例如 foo 或者 -f, --foo。

action - 指令行遇到參數時的動作,預設值是 store。

store_const,表示指派為const;

append,将遇到的值存儲成清單,也就是如果參數重複則會儲存多個值;

append_const,将參數規範中定義的一個值儲存到一個清單;

count,存儲遇到的次數;此外,也可以繼承 argparse.Action 自定義參數解析;

nargs - 應該讀取的指令行參數個數,可以是具體的數字,或者是?号,當不指定值時對于 Positional argument 使用 default,對于 Optional argument 使用 const;或者是 * 号,表示 0 或多個參數;或者是 + 号表示 1 或多個參數。

const - action 和 nargs 所需要的常量值。

default - 不指定參數時的預設值。

type - 指令行參數應該被轉換成的類型。

choices - 參數可允許的值的一個容器。

required - 可選參數是否可以省略 (僅針對可選參數)。

help - 參數的幫助資訊,當指定為 argparse.SUPPRESS 時表示不顯示該參數的幫助資訊.

metavar - 在 usage 說明中的參數名稱,對于必選參數預設就是參數名稱,對于可選參數預設是全大寫的參數名稱.

dest - 解析後的參數名稱,預設情況下,對于可選參數選取最長的名稱,中劃線轉換為下劃線.

然後對應程式中的内容:action - 指令行遇到參數時的動作,預設值是 store。是以sparse傳回的是 Ture,

以下同理:args.seed傳回的是72,資料類型是int

args.epochs傳回的是10000,資料類型是int

原文連結:https://blog.csdn.net/lly_zy/article/details/97130496

原文位址:https://www.cnblogs.com/Allen-rg/p/12234237.html