Python添加命令行参数
库名:argparse (内置模块)
官方教程:https://docs.python.org/zh-cn/3/howto/argparse.html?highlight=argparse
例子:
# 导入库
import argparse
# 1. 定义命令行解析器对象
parser = argparse.ArgumentParser(description='Demo of argparse')
# 2. 添加命令行参数
parser.add_argument('--epochs', type=int, default=30)
parser.add_argument('--batch', type=int, default=4)
# 3. 从命令行中结构化解析参数
args = parser.parse_args()
print(args)
epochs = args.epochs
batch = args.batch
print('show {} {}'.format(epochs, batch))
以上例子执行 example.py -h
后结果如下:
>python example.py -h
usage: example.py [-h] [--epochs EPOCHS] [--batch BATCH]
Demo of argparse
options:
-h, --help show this help message and exit
--epochs EPOCHS
--batch BATCH
参数详解
1. add_argument()
方法
parser.add_argument(name or flags...[, action][, nargs][, const][, default][, type][,choices][, required][, help][, metavar][, dest])
参数解释:
name or flags
:普通参数或flag参数选项参数的名称或标签,例如 epochs 或者 -e, –epochs。Flag参数不需要指定参数值,只需要带有参数名即可。action
:命令行遇到flags参数时的动作。有两个常见的动作,store_true:设定flag参数为true;store_false:设定flag参数为False。
注意:如果直接运行程序,默认不读取该变量,要使用必须要进行传参,例如:python example.py –epochs
nargs
:应该读取的命令行参数个数,可以是具体的数字,或者是?号,当不指定值时对于 Positional argument 使用 default,对于 Optional argument 使用 const;或者是 * 号,表示 0 或多个参数;或者是 + 号表示 1 或多个参数。default
:不指定参数时该参数的默认值。type
:命令行参数应该被转换成的数据类型。required
:是否为必选参数或可选参数。help
:参数的帮助信息。metavar
:在 usage 说明中的参数名称,对于必选参数,默认就是参数名称,对于可选参数默认是全大写的参数名称。dest
:解析后的参数名称,默认情况下,对于可选参数选取最长的名称,中划线转换为下划线。choices
:参数可允许的值的一个容器。const
:action 和 nargs 所需要的常量值。store_const
:表示赋值为constappend
:将遇到的值存储成列表,也就是如果参数重复则会保存多个值append_const
:将参数规范中定义的一个值保存到一个列表count
:存储遇到的次数;此外,也可以继承 argparse.Action 自定义参数解析
2. 解析命令行的参数:parse_args()
args = parser.parse_args()
在脚本中,通常 parse_args() 会被不带参数调用,而 ArgumentParser 将自动从 sys.argv 中确定命令行参数。