Python:参数解析器argparse的应用场景

目录

一、什么是argparse 

二、argparse的使用场景

三、argparse的使用流程

1.创建一个解析器,即创建 ArgumentParser() 对象

2.添加参数,即调用 add_argument() 方法添加参数

3.解析参数,即使用 parse_args() 解析添加的参数

4.简单而具体的例子(人话)

5.如何修改/配置参数值


一、什么是argparse 

        argparse 是一个用来解析命令行参数的 Python 库,它是 Python 标准库的一部分。argparse 模块使编写用户友好的命令行界面变得容易。程序定义了所需的参数,而 argparse 将找出如何从 sys.argv 中解析这些参数。argparse 模块还会自动生成帮助和使用消息,并在用户为程序提供无效参数时发出错误。

        简而言之,就是汇总函数接口,方便传参。

二、argparse的使用场景

        在深度学习代码中,特别是在train.py或test.py中,argparse最常被使用。因为在这些文件中,通常要对其他.py文件中定义的class或function进行调用,因此必然要传入大量的参数,如果不对这些参数进行集中编写,那么在冗长的代码中去找参数的定义位置或传参的位置将会十分麻烦。argparse为用户提供了集中编写所需参数的机会,下面的使用教程中我会结合简单而具体的例子进行说明。

三、argparse的使用流程

1.创建一个解析器,即创建 ArgumentParser() 对象

parser = argparse.ArgumentParser(description='test')

        description: 大多数对 ArgumentParser 构造方法的调用都会使用 description= 关键字参数。这个参数简要描述这个程度做什么以及怎么做。在帮助消息中,这个描述会显示在命令行用法字符串和各种参数的帮助消息之间。

2.添加参数,即调用 add_argument() 方法添加参数

parser.add_argument('--binary', action='store_true', default=False, help='action=store_true表示默认为False,当在命令行中使用--binary时自动变为True')
parser.add_argument('--number', type=int, default=6, help='普通数据,type可指定类型.')
parser.add_argument('--epochs', type=int, default=300, help='Number of epochs to train.')

        这里说一下如何定义参数的格式,可以暂时略过不看,粗体部分为比较常用的参数,其实每个都很常用:

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;

default :不指定参数时的默认值。
type:命令行参数应该被转换成的类型;
choices:参数可允许的值的一个容器;
nargs :应该读取的命令行参数个数,可以是具体的数字,或者是?号,当不指定值时对于 Positional argument 使用 default,对于 Optional argument 使用 const;或者是 * 号,表示 0 或多个参数;或者是 + 号表示 1 或多个参数。

required:可选参数是否可以省略 (仅针对可选参数)。
help:参数的帮助信息,当指定为 argparse.SUPPRESS 时表示不显示该参数的帮助信息.
metavar:在 usage 说明中的参数名称,对于必选参数默认就是参数名称,对于可选参数默认是全大写的参数名称.

dest:解析后的参数名称,默认情况下,对于可选参数选取最长的名称,中划线转换为下划线.

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

append:将遇到的值存储成列表,也就是如果参数重复则会保存多个值;
append_const:将参数规范中定义的一个值保存到一个列表;
count:存储遇到的次数;此外,也可以继承 argparse.Action 自定义参数解析;

3.解析参数,即使用 parse_args() 解析添加的参数

args = parser.parse_args()

4.简单而具体的例子(人话)

        例如我现在有一个.py文件,我现在定义了好多好多函数(为了方便我只定义了两个),我现在需要集中管理我传入的参数,使用argparse就会非常方便,对于本.py文件中的传参一目了然。

import argparse

parser = argparse.ArgumentParser(description='test')

parser.add_argument('--spring', action='store_true', default=False, help='nothing.')
parser.add_argument('--summer', type=int, default=6, help='num.')
parser.add_argument('--fall', type=int, default=11, help='num.')
parser.add_argument('--winter', type=int, default=100, help='Number of epochs to train.')

args = parser.parse_args()
# FLAGS, unparsed = parser.parse_known_args() 这种解析方法用的比较少,有兴趣可以了解一下

def sum_function(num2sum_1,num2sum_2):
    sum_result = num2sum_1 + num2sum_2
    return sum_result

def multiply_function(num2multiply_1,num2multiply_2):
    multiply_result = num2multiply_1 * num2multiply_2
    return multiply_result


print('args.spring的值是{}'.format(args.spring))
print('args.summer的值是{}'.format(args.summer))
print(sum_function(args.summer,args.fall))
print(multiply_function(args.summer,args.winter))
# 运行结果
args.spring的值是False
args.summer的值是6
17
600

        你可以发现,对本文件中的函数进行传参,无论有多少参数需要传,我们只要在argparse中写好需要传的参数,在传参时传入args.参数名,需要修改传参值时,统一在argparse中进行修改即可,这样就方便了参数的管理。

5.如何修改参数值

        这方面我了解得不太全面,我说一下我掌握的方法吧。第一,对于有default的参数,直接修改default的值即可;

        第二,用命令行运行,例如在上面举例的程序,我如果想把summer的值改为10,fall的值改为20,那么命令行指令就是:python train.py --summer 10 --fall 20;如果我同时还想让spring的值成为True,那么命令行指令为:python train.py --summer 10 --fall 20 --spring,下面为运行结果:

args.spring的值是True
args.summer的值是10
30
1000

        第三,在Edit Configurations中进行配置,然后run即可:

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Taylor不想被展开

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值