python官网的链接:Argparse Tutorial — Python 3.6.8 documentation
1.The basics
由此我们可以知道,运行不加任何参数的时候,运行但是没有任何结果。--help是函数自带的可选参数,我们可以从结果中看出,可以简写为-h。
2.introducing positional arguments
这里,我们使用 add_argument()来指定我们的参数名称。添加位置参数以后,命令行必须添加一个参数。这个parse_args()是从指定参数返回数据,这里我们返回的就是echo。
接下来我们仔细观察,虽然我们设置了一个参数echo,但帮助信息能告诉我们的仅仅是echo是一个position argument,不像--help,后面有一个句子解释其功能。所以接下来,我们可以让这个echo,拥有更加完整的信息。
接下来,我们可以写一个更有用的位置参数square。
这里默认的参数是str,除非我们额外说明一下,不是str,而是int,就可以了。我们来看一下。
3.introducing optional arguments
这里的意思就是,当-v被指定的时候,我们可以输出一些信息,没有指定-v的时候,就不会输出这些信息。因此,当我们没有输入-v的时候,程序运行是不会报错的。然后我们可以看到,可选参数的设置加上的是--或者-,打印帮助信息的时候,他们就出现在可选参数的位置了。这里还有一点,当我们使用-v参数的时候,一定要指定一个值,任何值或者字符串都可以。
这里我们的action就是给-v一个返回值True,如果没有-v参数出现的时候,就是返回false,当然我们也可以将action设置false,你会发现,将不会返回print语句的内容了。
4.short options
这里的-v就是short options,因此在命令行输入-v,和--verbose是一样的。
5.combining positional and optional arguments
这里我们参数的位置是不固定的。
那么如果我想输出的值不仅仅只有两种,也就是不只是True和false两种情况应该怎么办?还记得前面的内容吗?当我们没有给-v参数一个action的时候,是不是后面必须跟一个值,任何值都可以,因此这里当我们想要输出3种或者以上的结果的时候,我们可以利用一下这个特点。
我们可以看到,这里可以在-v后面输入任何值的整数,但是如果我想限制只能输入有限个参数应该怎么办呢?或者输入范围间的整数。一起看看。
我们来看一种action的新的用法:
这里我们注意到。不论-vvvvv有多少-v,都会运行else语句,但是帮助文档对此没有任何提示的。我们简单的修复一下这个bug。
为什么呢?我们接着往下看。
这时候不加参数是不是就可以了,我们设定默认值为0,因此当不加-v参数的时候,就是运行else语句的内容了。我们之所以设定初始值,是为了让它可以和其它int值相比较,如果不指定的话,它会得到一个none值,就不能和其它作比较了。错误类型如下:
这个default并不一定是0,1,2,3,4,都可以,只是为了让参数返回一个int,可以和其它的数值相比较。
6.getting a little more advanced
让我们的小程序完成一些不止计算平方的小工作。
到目前我们都是利用-v参数去改变我们显示的内容。接下来看看-v的更多用途。