【教程搬运】读懂github上的工程代码——带你熟悉Python中的Parser

我们经常会遇到类似于这样的训练命令,里面用“–”指定了很多option的名称和数值,例如python test.py --dataroot ./datasets/facades --name facades_pix2pix --model pix2pix --direction BtoA,如果要编写出这样的命令,就不得不用到一个叫Argparse的包,让我们来看看它是如何使用的。教程链接如下https://www.jb51.net/article/212035.htm,我来详细说明这个教程里的问题。

更为详细的说明文档在这里,但是也没必要把这个教程看一遍,需要的时候去查阅就可以了。https://docs.python.org/zh-cn/3/library/argparse.html

1.导入包

调用这个包的第一步永远是导入,所以代码如下:

import argparse

2.实例化ArgumentParser

# 实例化
# 创建一个 ArgumentParser 对象
# ArgumentParser 对象包含将命令行解析成 Python 数据类型所需的全部信息。
parser = argparse.ArgumentParser(description = 'test')

description里头写的是一些描述信息。这一点不难理解。这个参数简要描述这个程序做什么以及怎么做。在帮助消息中,这个描述会显示在命令行用法字符串和各种参数的帮助消息之间。

3.使用add_argument函数添加参数

我们首先看三行的样例:

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

我们不难看出,上面的各项参数都遵从着这样一个格式:ArgumentParser.add_argument(name or flags...[, action][, nargs][, const][, default][, type][, choices][, required][, help][, metavar][, dest])
我们解释如下:

  • name or flags
    这是选项字符串的名字或者列表,也就是命令行里头两个减号“- -”之后的部分。
  • action
    命令行遇到参数时的动作,默认值是 store_true,什么意思呢?就是如果出发了前方name or flags里头的关键字,那么这个地方就会被显示为true,比方说parser.add_argument('--sparse', action='store_true', default=False, help='GAT with sparse version or not.'),之恩要我后面的命令是python xx.py --sparse,好了,触发了sparse,此处立刻变为true。
  • type
    命令行参数应该被转换成的类型。
  • choices
    参数可允许的值的一个容器,也就是说,参数只能取这些值。
  • default
    不指定参数时的默认值。
  • required
    可选参数是否可以省略 (仅针对可选参数)。

下面这些相比之下就不那么常见了。

  • store_const
    表示赋值为const。
  • append
    将遇到的值存储成列表,也就是如果参数重复则会保存多个值;
  • append_const
    将参数规范中定义的一个值保存到一个列表;
  • count
    存储遇到的次数;此外,也可以继承 argparse.Action 自定义参数解析;
  • nargs
    应该读取的命令行参数个数,可以是具体的数字,或者是?号,当不指定值时对于 Positional argument 使用 default—对于 Optional argument 使用 const;或者是 * 号,表示 0 或多个参数;或者是 + 号表示 1 或多个参数。
  • const
    action 和 nargs 所需要的常量值。
  • help
    参数的帮助信息,当指定为 argparse.SUPPRESS 时表示不显示该参数的帮助信息.
  • metavar
    在 usage 说明中的参数名称,对于必选参数默认就是参数名称,对于可选参数默认是全大写的参数名称.
  • dest
    解析后的参数名称,默认情况下,对于可选参数选取最长的名称,中划线转换为下划线.

4.使用parse_args解析参数

ArgumentParser 通过 parse_args() 方法解析参数。它将检查命令行,把每个参数转换为适当的类型然后调用相应的操作。

# 解析参数
args = parser.parse_args()

这个时候,我们就可以看看下面例子,怎么样,懂了么?

#导入包
import argparse
#实例化
parser = argparse.ArgumentParser(description='test')
#添加选项(比如本例子中是添加了3个)
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)
'''
False
72
10000
'''

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

鲤鱼王的成长之路

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

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

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

打赏作者

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

抵扣说明:

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

余额充值