Python参数解析模块sys、getopt、argparse使用与对比分析
作者:Together_CZ 发布时间:2021-12-19 17:39:58
一些命令行工具的使用能够大大简化代码脚本的维护成本,提升复用性,今天主要是借助于python提供的几种主流的参数解析工具来实现简单的功能,主要是学习实践为主,这是新年伊始开工的第一篇,还是花了一番功夫来完成写作的和实验的,希望能够帮到需要的朋友们,新的一年里,祝大家心想事成!
好了,废话不多说,下面进入正文。
Python中有三个内建的模块用于处理命令行参数:
第一个:sys,最简单,只能够提供简单的参数解析功能
第二个:getopt,只能简单的处理命令行参数 ,较sys封装更好一点
第三个:argparse,使其更加容易的编写用户友好的命令行接口。它所需的程序进程了参数定义,argparse将更好的解析 sys.argv。同时argparse模块还能自动生成帮助及用户输入错误参数时的提示信息。
在命令行参数中分为“-”和“--”两种模式,具体的使用方法以及与异同点我都会在下面的实际使用中介绍到,主要是正确完成对两种命令参数模式的区分就行了。接下来的实践中,首先以sys模块为例,来观察该模块的参数解析过程,具体实践如下:
def sysFunc():
'''
基于 sys 模块的简单参数解析功能
选项的写法要求:
对于短格式:
"-"号后面要紧跟一个选项字母,如果还有此选项的附加参数,可以用空格分开,也可以不分开。
长度任意,可以用引号。
如: -h -ls -l s 等等
对于长格式:
"--"号后面要跟一个单词,如果还有些选项的附加参数,后面要紧跟"=",再加上参数。
"="号前后不能有空格。
如: --input=data.txt
长格式是在Linux下引入的,许多Linux程序都支持这两种格式。在Python中提供了getopt模块很好
的实现了对着两种用法的支持,而且使用简单。
执行示例:
python demo.py -d data.txt
python demo.py --data=data.txt
'''
if len(sys.argv)==1:
print 'Nothing need to be done!'
sys.exit()
else:
para_list=sys.argv
print 'Parameters is: ',para_list
if para_list[1].startswith('--'):
print 'DataFile name is: ',para_list[1].split('=')[-1].strip()
print 'Longopts,do your actions here!!!'
elif para_list[1].startswith('-'):
print 'DataFile name is: ',para_list[2]
print 'Shortopts,do your actions here!!!'
关于该模块的使用和注意事项我在上面的代码片段中已经解释清楚了,相信很容易理解,我也附上了执行示例,接下来我们执行一下上述代码结果如下:
接下来我们使用getopt模块来进行参数命令行的解析操作,代码中我们选用IP和端口两个属性作为待传入的参数,具体实践如下:
def getoptFunc():
'''
基于 getopt 模块来实现参数解析功能
函数getopt(args,shortopts,longopts=[])
参数args一般是sys.argv[1:]
shortopts 短格式 (-)
longopts 长格式(--)
注意点:
定义命令行参数时,要先定义带'-'选项的参数,再定义没有‘-'的参数
执行示例:
python demo.py -i 172.19.7.217 -p 8066 data.txt 88
python demo.py --ip=172.19.7.217 --port=8066 data.txt 88
'''
if len(sys.argv)==1:
print 'Nothing need to be done!'
sys.exit()
try:
opts,args=getopt.getopt(sys.argv[1:],"hp:i:",["help","ip=","port="]) #过滤掉脚本名称
'''
opts是个包含元祖的列表,args是个列表,包含那些没有‘-'或‘--'的参数
短格式 --- h 后面没有冒号:表示后面不带参数,p:和 i:后面有冒号表示后面需要参数
长格式 --- help后面没有等号=,表示后面不带参数,其他三个有=,表示后面需要参数
'''
print 'opts: ',opts
print 'args: ',args
except getopt.GetoptError:
print "argv error,please input"
sys.exit()
#打印具体参数
map_dict={'-i':'IP','--ip':'IP','-p':'Port','--port':'Port'}
for name,value in opts:
if name in ("-h","--help"):
print """
Usage:sys.args[0] [option]
-h or --help:显示帮助信息
-p or --ip: IP地址
-p or --port: IP端口
"""
if name in ('-i','--ip','-p','--port'):
print '{0} is=======>{1}'.format(map_dict[name],value)
使用getopt模块分析命令行参数大体上分为三个步骤:
1.导入getopt, sys模块
2.分析命令行参数
3.处理结果
同样我们加入了详细的注释与说明帮助理解该模块的工作机制,我们也附上了相关的执行示例,运行上述代码得到的结果如下图所示:
最后我们实践一下argparse模块,该模块相对于前两个模块而言,封装程度更为高级,使用也更为方便一下,具体的实践如下:
def argparseFunc():
'''
基于argparse模块实现高级的参数解析功能
执行示例:
python demo.py -i 172.19.7.236 -p 7077 -f -w
python demo.py -i 172.19.7.236 -p 7077 -f -r
'''
parser=argparse.ArgumentParser(description="show example") #使用argparse的构造函数来创建对象
parser.add_argument("-i","--ip",help="IP Address") #添加可解析的参数
parser.add_argument("-p","--port",help="IP Port") #添加可解析的参数
parser.add_argument("-f","--flag",help="Flag",action="store_true") #action=store_true的意义是如果使用了这个参数则值默认为TRUE
exptypegroup=parser.add_mutually_exclusive_group() #添加一组互斥的选项,如上例中的-l和-r只能用一个
exptypegroup.add_argument("-r","--read",help="Read Action",action="store_true")
exptypegroup.add_argument("-w","--write",help="Write Action",action="store_true")
ARGS=parser.parse_args()
print 'ARGS:',ARGS
if ARGS.ip:
print "IP is: "+ARGS.ip
if ARGS.port:
print "Port is: "+ARGS.port
if ARGS.flag:
print "Flag is: "+str(ARGS.flag)
if ARGS.read:
print "Read action is: "+str(ARGS.read)
if ARGS.write:
print "Write action is: "+str(ARGS.write)
该模块的使用较为广泛,首先使用该模块提供的构造函数来创建一个ArgumentParser对象,后续的参数传入和指定等工作都是基于ArgumentParser对象来进行的,其中,add_argument用来添加参数对象选项,add_mutually_exclusive_group用于添加互斥的选项,比如:上述的读操作和写操作就是互斥的,上述代码中我们给出了执行示例,同样我们依旧是基于IP和端口两个参数选项进行实验,结果如下所示:
我们想知道,声明好的互斥的参数选项是否真的是不能同时使用呢?这里简单的执行一下就行了:
从上面的error信息中我们看到了argparse模块给我们的反馈信息是读写操作不被允许同时使用,说明了上述我们声明的互斥参数是正常工作了的。
三个模块,三种参数解析的实践也只能是对其达到初步了解的目的,希望有了一定的了解与认识之后再使用到具体的项目中去相信效果会更好一些。
来源:https://blog.csdn.net/Together_CZ/article/details/87619122


猜你喜欢
- code原文档 1.txt :HelloNanjing100实现代码:file_ = "1.txt"r_file = o
- 废话不多说,看代码吧!'''待完善。此代码实现了,根据标注文本的属性,数值,位置,及 容差,去判断 设计 和 实测两
- 一、内置函数下面简单介绍几个:1.abs() 求绝对值2.all() 如果 iterable 的所有元素都为真(或者如果可迭代为空),则返回
- 1.流程控制语 break用于结束整个循环结构,直接退出整个循环例:用两种循环模拟密码输入输入正确就退出循环,输入错误可以重新输入,有三次输
- 装饰器简介:装饰器(decorator)是一种高级Python语法。装饰器可以对一个函数、方法或者类进行加工。在Python中,我们有多种方
- 听说安全地断开Connection连接的记录集可以提高ASP的运行速度,请问如何实现?很多人会将一个Connection对象存储在Appli
- 程序设计是困难的,其核心是管理的复杂性。计算机程序是人类做出的最复杂的东西。质量是不可靠的且隐蔽的。好的体系架构是必需给程序足够的结构使其健
- 第1步:打开Navicat,双击打开你要导出表结构的数据库,点击“查询”—&am
- 前言这几天caffe2发布了,支持移动端,我理解是类似单片机的物联网吧应该不是手机之类的,试想iphone7跑CNN,画面太美~作为一个刚入
- 用过mac的朋友都反映很好用,不仅美观,性能好,关键是他的系统底层对于开发人员来说,无疑就是一个最大的好处,用习惯linux的人就知道mac
- 比如input中的数据和data中的msg双向绑定。那么我们可以 判断先把msg以空格拆分成数组,然后拼接起来,判断字符串的长度
- 一、介绍Python:python代码解释器,用于编译.py代码,python可以单独安装,本次环境配置目的用于解决计算机视觉处理,因此选用
- 介绍最近在项目中遇到插入数据瓶颈,几万、几十万、几百万的数据保存到MYSQL数据库,使用EF插入数据速度非常慢,数据量非常大时EF插入需要几
- 1、python教程基于 python3.10 的持续解读,旨在快速回忆加深理解,节约自己的时间成本1.1 概述python 是一门易于学习
- 让左模糊查询也能走索引测试表USER_INFO表数据以及结构如下有一个USER_NAME字段的索引有个业务需求,需要模糊搜索出用户名后几位有
- 效果图最近帮朋友写个简单爬虫,顺便整理了下,搞成了一个带GUI界面的小说爬虫工具,用来从笔趣阁爬取小说。开发完成后的界面采集过程界面采集后存
- Mysql Work Space右键新建的数据库BMI,设置为此次连接的默认数据库,接下来的所有操作都将在这个数据库下进行将bmi下拉单展开
- JavaScript 中的 this 指向问题有很多文章在解释,仍然有很多人问。上周我们的开发团队连续两个人遇到相关问题,所以我不得不将关于
- 1.按需加载第三方库例如 ElementUI、lodash 等a, 装包npm install babel-plugin-component
- 一 前言官方解释:https://www.elastic.co/guide/en/elasticsearch/reference/6.0/r