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 相关文章推荐
python通过线程实现定时器timer的方法
Mar 16 Python
python模块之re正则表达式详解
Feb 03 Python
Python进度条实时显示处理进度的示例代码
Jan 30 Python
numpy返回array中元素的index方法
Jun 27 Python
Django框架使用富文本编辑器Uedit的方法分析
Jul 31 Python
Django Rest framework之权限的实现示例
Dec 17 Python
python实现门限回归方式
Feb 29 Python
python 中的9个实用技巧,助你提高开发效率
Aug 30 Python
Python使用windows设置定时执行脚本
Nov 12 Python
使用pandas实现筛选出指定列值所对应的行
Dec 13 Python
python实现跨年表白神器--你值得拥有
Jan 04 Python
python爬虫beautifulsoup库使用操作教程全解(python爬虫基础入门)
Feb 19 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出错界面
2006/10/09 PHP
php 获取select下拉列表框的值
2010/05/08 PHP
PHP下通过file_get_contents的代理使用方法
2011/02/16 PHP
过滤掉PHP数组中的重复值的实现代码
2011/07/17 PHP
PHP5权威编程阅读学习笔记 附电子书下载
2012/07/05 PHP
PHP中substr()与explode()函数用法分析
2014/11/24 PHP
PHP中使用register_shutdown_function函数截获fatal error示例
2015/04/21 PHP
php微信开发之图片回复功能
2018/06/14 PHP
JQuery 网站换肤功能实现代码
2009/11/02 Javascript
javascript使用正则获取url上的某个参数
2014/09/04 Javascript
JS简单操作select和dropdownlist实例
2014/11/26 Javascript
JS制作简单的三级联动
2015/03/18 Javascript
为什么JavaScript没有块级作用域
2016/05/22 Javascript
jQuery中设置form表单中action值的实现方法
2016/05/25 Javascript
深入理解angularjs过滤器
2016/05/25 Javascript
jQuery实现扑克正反面翻牌效果
2017/03/10 Javascript
浅谈Vuex的状态管理(全家桶)
2017/11/04 Javascript
ssm+vue前后端分离框架整合实现(附源码)
2020/07/08 Javascript
Python中zip()函数用法实例教程
2014/07/31 Python
Windows8下安装Python的BeautifulSoup
2015/01/22 Python
Python数据结构与算法之使用队列解决小猫钓鱼问题
2017/12/14 Python
python使用Tesseract库识别验证
2018/03/21 Python
Python多线程编程之多线程加锁操作示例
2018/09/06 Python
python sklearn库实现简单逻辑回归的实例代码
2019/07/01 Python
python命令行工具Click快速掌握
2019/07/04 Python
Django密码系统实现过程详解
2019/07/19 Python
python去除删除数据中\u0000\u0001等unicode字符串的代码
2020/03/06 Python
python爬虫工具例举说明
2020/11/30 Python
在求职信中如何凸显个人优势
2013/10/30 职场文书
电教室标语
2014/06/20 职场文书
雷锋式好少年事迹材料
2014/08/17 职场文书
电工实训报告总结
2014/11/05 职场文书
《秋天的图画》教学反思
2016/02/19 职场文书
深入理解java.lang.String类的不可变性
2021/06/27 Java/Android
使用Ajax实现无刷新上传文件
2022/04/12 Javascript
bose降噪耳机音能消除人声吗
2022/04/19 数码科技