python 如何利用argparse解析命令行参数


Posted in Python onSeptember 11, 2020

命令行参数工具是我们非常常用的工具,比如当我们做实验希望调节参数的时候,如果参数都是通过硬编码写在代码当中的话,我们每次修改参数都需要修改对应的代码和逻辑显然这不太方便。比较好的办法就是把必要的参数设置成通过命令行传入的形式,这样我们只需要在运行的时候修改参数就可以了。

sys.argv

解析命令行传入参数最简单的办法就是通过sys.argv,sys.argv可以获取到我们通过命令行传入的参数。

import sys

print(sys.argv)

用法很简单,只需要调用sys.argv即可。argv是一个数组,如果参数有多个,我们可以通过下标进行访问。但是有一点需要注意,argv当中存储的结果是从Python调用开始的。

我们来看一个例子,我们随意传入一些参数,print sys.argv之后是这样的。

python test.py -a -c -d=222 
>>> ['test.py', '-a', '-c', '-d=222']

也就是说我们python运行test.py这个文件名也当做参数之一,所以我们要获取自定义参数的话需要从argv[1]开始。

sys.argv的好处是方便,我们只需要访问它就可以拿到传入的参数了。但是缺点也很明显,就是功能太少了。假如我们是看其他大神的代码,我们想要知道运行的时候需要传入什么参数,以及每个参数代表什么含义就做不到了。

为了解决这个问题,我们需要使用封装更多功能的工具,也是本篇文章的核心——argparse。

基本用法

argparse是Python当中的一个库,我们需要先import一下,这个库我没记错应该是Python自带的,也不需要安装,我们直接就可以使用。

在我们使用之前,我们需要先初始化这个parse,也就是一个参数解析器。

# 这里ArgumentParser可以传入一个字符串,表示用途
parser = argparse.ArgumentParser()
parser.parse_args()

这个时候其实就已经有了一个解析器了,我们在运行的时候可以传入参数-h,表示help,也就是查看目前解析器当中定义的参数。由于我们现在什么也没有,所以能显示出来的就只有help。

python 如何利用argparse解析命令行参数

必选参数

首先我们来介绍必选参数,它的定义和函数当中的必填参数是一样的,也就是说我们运行程序必须要的参数。如果不传,那么程序不应该执行会进行报错并提示。

定义必选参数的方法非常简单,我们只需要通过add_argument传入参数的名称就可以了。

import argparse

parser = argparse.ArgumentParser("For test the parser")
parser.add_argument('test')
args = parser.parse_args()

print(args.test)

这样我们就定义了一个名叫test的参数,我们可以通过args.test来访问它。

这个时候我们再运行python test.py -h就会发现提示的信息当中多了一行:

python 如何利用argparse解析命令行参数

告诉我们必选参数当中有test,必选参数直接传入,不需要加上前缀。所以我们执行的时候直接python test.py xxx就可以了。

可选参数

有必选参数当然就有可选参数,可选参数由于可选可不选, 所以我们在使用的时候需要在参数前加上标识-或者--。比如我们参数名叫做test,可以定义成-test或者--test,这两种都可以,也可以这两种都定义。

parser.add_argument('-test', '--test')

我们运行-h可以发现optional arguments当中多了test和--test。

python 如何利用argparse解析命令行参数

但是这个只print出来了参数名,并没有告诉我们这个参数究竟是做什么的,像是help参数后面就跟了show this help message and exit这个提示语。如果我们也希望help能够提示我们参数的作用怎么办呢?

我们可以通过help参数传入我们希望打印出来的提示语,这样方便使用者在使用的时候了解参数的情况。

比如我们把这行语句改成:

parser.add_argument('-test', '--test', help='just for help')

这样当我们运行的时候,就会看到提示语了:

python 如何利用argparse解析命令行参数

默认值

如果参数很多的时候,我们有时候可能不希望每一个都指定一个值,而是希望可以在不填的时候有一个默认值。这个想法非常正常,想要做到这点也很简单,我们可以通过default参数来指定。

import argparse

parser = argparse.ArgumentParser("For test the parser")
parser.add_argument('-test', '--test', default=1, help='just for help')
args = parser.parse_args()

print(args.test)

比如这样我们在代码当中把test参数的默认值设置成了1,当我们运行的时候,如果不填test这个参数的话,那么程序就会使用它的默认值也就是1。

但有一点默认值的信息并不会print在help当中,所以我们需要自己在提示语当中告知使用者默认值是多少。

type

我们可以定义参数的默认值,当然也可以定义它的类型。

因为命令行传入的参数默认都是字符串,如果我们要进行数学上的计算,使用str还需要自己转换,这就很不方便。我们可以在传入参数的时候就完成类型的匹配,这样如果传入参数的类型不对, 那么直接报错,不往下运行。

想要做到这点也很简单,通过type参数就可以实现。

parser.add_argument('-test', '--test', default=1, type=int, help='just for help')

比如当我们定义了一个int型的参数,而传入的是类型不匹配的话,那么就会引起报错:

python 如何利用argparse解析命令行参数

报错信息当中写得很清楚,我们得到了一个无效的int的值,它是abc。

可选值

它同样还支持可选值,可选值很好理解,就是我们希望限定传入参数的范围仅仅在几个值当中。比如说我们希望传入的值不是0就是1,或者是在某几个具体的值当中,这个时候我们可以通过choices参数来实现这一点。

choices参数传入的是一个list,也就是我们的限定范围,只有在这个范围当中的值才被允许。

parser.add_argument('-test', '--test', default=1, choices=[2, 3, 4], type=int, help='just for help')

如果我们运行传入test=1,那么就会引起报错,告诉我们传入的值不在choices范围当中。

python 如何利用argparse解析命令行参数

这是一个挺有意思的例子,仔细看会发现我们默认值设置成了1,但是可选值当中并没有1。这也是允许的,默认值可以不在可选值范围内,但是当我们传入1就会触发可选值校验。

action

action是一个很神奇也很有用的操作,可以指定参数的处理方式。我们默认的方式是store,也就是存储的意思,这个我们都能理解。除此之外,还有store_true,它表示出现则是true,否则是false。

parser.add_argument('-test', '--test', action='store_true', help='just for help')

当我们把test参数的定义改成这样之后,我们来对比一下运行的结果就明白了。

python 如何利用argparse解析命令行参数

除了store_true之外还有store_const,也就是说出现就指定为一个固定值。

parser.add_argument('-test', '--test', action='store_const', const=23, help='just for help')

这样当我们指定-test参数之后,它会自动被赋值成23。

除了这两个之外,另外一个很常用的参数是append,可以将多次出现的同一个参数自动存入一个list当中。

parser.add_argument('-test', '--test', action='append', type=int, help='just for help')

python 如何利用argparse解析命令行参数

nargs

nargs也是一个非常有用的参数,可以对参数进行一些花式操作。nargs的传入参数有以下几种,首先是N,也就是一个整数。代表可以接收N个参数值,这N个值会被存入一个list当中。

parser.add_argument('-test', '--test', nargs=2, type=int, help='just for help')

另外一种传入的参数是'+'或者是'*',它可以将任意多个值存入一个list当中。

parser.add_argument('-test', '--test', nargs='*', type=int, help='just for help')

python 如何利用argparse解析命令行参数

总结

有了parser之后,我们在Python当中处理命令行参数会变得非常简单,我们可以做各种各样的定制化操作。除了我们上面介绍的之外,还有一些其他的做法,相对来说不是非常常用,所以就不一一穷尽了,感兴趣的同学可以自行了解一下。

以上就是python 如何利用argparse解析命令行参数的详细内容,更多关于python 解析命令行的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
将Django使用的数据库从MySQL迁移到PostgreSQL的教程
Apr 11 Python
python删除指定类型(或非指定)的文件实例详解
Jul 06 Python
关于numpy中np.nonzero()函数用法的详解
Feb 07 Python
Python使用 Beanstalkd 做异步任务处理的方法
Apr 24 Python
numpy.ndarray 交换多维数组(矩阵)的行/列方法
Aug 02 Python
python程序运行进程、使用时间、剩余时间显示功能的实现代码
Jul 11 Python
PYTHON实现SIGN签名的过程解析
Oct 28 Python
使用python实现男神女神颜值打分系统(推荐)
Oct 31 Python
Python常用模块sys,os,time,random功能与用法实例分析
Jan 07 Python
Python中断多重循环的几种方式详解
Feb 10 Python
Python filter过滤器原理及实例应用
Aug 18 Python
Pytest allure 命令行参数的使用
Apr 18 Python
Python Pivot table透视表使用方法解析
Sep 11 #Python
Python extract及contains方法代码实例
Sep 11 #Python
python 利用zmail库发送邮件
Sep 11 #Python
浅析Python 责任链设计模式
Sep 11 #Python
详解python命令提示符窗口下如何运行python脚本
Sep 11 #Python
python实现邮件循环自动发件功能
Sep 11 #Python
Python 实现微信自动回复的方法
Sep 11 #Python
You might like
浅析PHP中call user func()函数及如何使用call user func调用自定义函数
2015/11/05 PHP
jQuery的Ajax时无响应数据的解决方法
2010/05/25 Javascript
jQuery 表单验证扩展(四)
2010/10/20 Javascript
jquery 插件开发 extjs中的extend用法小结
2013/01/04 Javascript
js替换字符串的所有示例代码
2013/07/23 Javascript
js动态创建、删除表格示例代码
2013/08/07 Javascript
Javascript获取CSS伪元素属性的实现代码
2014/09/28 Javascript
JavaScript实现简单的二级导航菜单实例
2015/04/15 Javascript
javascript中indexOf技术详解
2015/05/07 Javascript
jQuery链式调用与show知识浅析
2016/05/11 Javascript
AngularJS辅助库browserTrigger用法示例
2016/11/03 Javascript
Bootstrap Modal遮罩弹出层(完整版)
2016/11/21 Javascript
利用Query+bootstrap和js两种方式实现日期选择器
2017/01/10 Javascript
angular bootstrap timepicker TypeError提示怎么办
2017/06/13 Javascript
javaScript和jQuery自动加载简单代码实现方法
2017/11/24 jQuery
Angular异步变同步处理方法
2018/08/13 Javascript
NodeJs入门教程之定时器和队列
2019/03/08 NodeJs
layui 点击重置按钮, select 并没有被重置的解决方法
2019/09/03 Javascript
vue-loader中引入模板预处理器的实现
2019/09/04 Javascript
jQuery中getJSON跨域原理的深入讲解
2020/09/02 jQuery
在python3环境下的Django中使用MySQL数据库的实例
2017/08/29 Python
对numpy中数组元素的统一赋值实例
2018/04/04 Python
python模块导入的细节详解
2018/12/10 Python
python代码 输入数字使其反向输出的方法
2018/12/22 Python
简单了解python的一些位运算技巧
2019/07/13 Python
django如何实现视图重定向
2019/07/24 Python
Python closure闭包解释及其注意点详解
2019/08/28 Python
Python安装whl文件过程图解
2020/02/18 Python
python实现电子词典
2020/03/03 Python
定义一结构体数组表示分数,并求两个分数相加之和
2013/06/11 面试题
党员教师四风自我剖析材料
2014/09/30 职场文书
技术股份合作协议书
2014/10/05 职场文书
党的群众路线教育实践活动领导班子整改方案
2014/10/25 职场文书
2014年学生会生活部工作总结
2014/11/07 职场文书
运动会广播稿20字
2015/08/19 职场文书
ant design vue的form表单取值方法
2022/06/01 Vue.js