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的多态性实例分析
Jul 07 Python
Python写入CSV文件的方法
Jul 08 Python
python实现媒体播放器功能
Feb 11 Python
python数据处理 根据颜色对图片进行分类的方法
Dec 08 Python
Python根据成绩分析系统浅析
Feb 11 Python
pandas dataframe的合并实现(append, merge, concat)
Jun 24 Python
python 输出列表元素实例(以空格/逗号为分隔符)
Dec 25 Python
Pytorch之contiguous的用法
Dec 31 Python
Windows下PyCharm配置Anaconda环境(超详细教程)
Jul 31 Python
Pycharm自动添加文件头注释和函数注释参数的方法
Oct 23 Python
利用Python多线程实现图片下载器
Mar 25 Python
python开发制作好看的时钟效果
May 02 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
全国FM电台频率大全 - 20 广西省
2020/03/11 无线电
php email邮箱正则
2008/10/08 PHP
php实现的CSS更新类实例
2014/09/22 PHP
PHP实现自动登入google play下载app report的方法
2014/09/23 PHP
thinkphp5.1 文件引入路径问题及注意事项
2018/06/13 PHP
基于Laravel 多个中间件的执行顺序详解
2019/10/21 PHP
web 页面分页打印的实现
2009/06/22 Javascript
基于jquery的无刷新分页技术
2011/06/11 Javascript
JQuery防止退格键网页后退的实现代码
2012/03/23 Javascript
A标签触发onclick事件而不跳转的多种解决方法
2013/06/27 Javascript
jQuery对象与DOM对象之间的相互转换
2015/03/03 Javascript
JavaScript获取并更改input标签name属性的方法
2015/07/02 Javascript
Jquery和angularjs获取check框选中的值的方法汇总
2016/01/17 Javascript
一道关于JavaScript变量作用域的面试题
2016/03/08 Javascript
Vuejs第七篇之Vuejs过渡动画案例全面解析
2016/09/05 Javascript
CSS3 media queries结合jQuery实现响应式导航
2016/09/30 Javascript
BootStrap实现鼠标悬停下拉列表功能
2017/02/17 Javascript
javascript 中关于array的常用方法详解
2017/05/05 Javascript
Vue实现选择城市功能
2017/05/27 Javascript
微信小程序实现美团菜单
2018/06/06 Javascript
Angular路由ui-router配置详解
2018/08/01 Javascript
如何用Node写页面爬虫的工具集
2018/10/26 Javascript
详解 微信小程序开发框架(MINA)
2019/05/17 Javascript
Vue 打包的静态文件不能直接运行的原因及解决办法
2020/11/19 Vue.js
有关wxpython pyqt内存占用问题分析
2014/06/09 Python
Python random模块常用方法
2014/11/03 Python
Python实现大文件排序的方法
2015/07/10 Python
window下eclipse安装python插件教程
2017/04/24 Python
pandas数据集的端到端处理
2019/02/18 Python
Django 设置多环境配置文件载入问题
2020/02/25 Python
软件测试面试题
2015/10/21 面试题
《郑和远航》教学反思
2014/04/16 职场文书
体育教师求职信
2014/06/30 职场文书
2014年酒店前台工作总结
2014/11/14 职场文书
古诗之感恩老师
2019/10/24 职场文书
PyTorch 如何检查模型梯度是否可导
2021/06/05 Python