argparse库
01.库安装
argparse库是python自带的命令行参数解析包,不仅可以从用户命令行中获取参数,还可以自动化的输出帮助内容,使用import argparse
来判断是否已经安装了这个库,如果没有,其安装的方式也非常的简单,使用pip install argparse
就可以直接安装。
02.创建参数解析对象
在使用前,首先需要创建一个参数的解析器,在显示help时就会显示出他的描述,当然,括号中的参数可有可无。
parse = argparse.ArgumentParser(description='description')
这样就生成了一个名为parse的解析对象。
03.添加参数列表
为这个对象添加一些参数,使用add_argument
方法,其原型为:
parse.add_argument(name or flags…[, action][, nargs][, const][, default][, type][, choices][, required][, help][, metavar][, dest])
04.选项name\flag\action\default\type\help
第一个参数为接收用户数输入的标志,例如--path
,-y
等,其后紧跟的选项为可选项,具体为:
parse.add_argument('-y',action = 'store_false/store_ture',default = False,help = 'this is help')
这句话中的参数-y存在时,表示了action中的false或true,当不存在时,则为默认值False,这类参数类似于一个判断,yes or no,还有一类参数可以设置获取到参数的类型,int、str
等,这类型的参数会将用户输入保存下来,用于最后的操作,例如;
parse.add_argument('-path',type=str,default ='c:',help = 'cd to this path')
上面设置的两个参数都需要使用parse.parse_args()
解析,解析后将其赋值给一个变量,这个变量将会保存用户输入的所有参数内容,具体用法为:
args = parse.parse_args()
print args
执行时可以看到我们的输入都被储存了下来。
使用-h获取帮助列表。
通过args.path、args.y可以分别对这两个值操作,完成我们需要的目标。
05.选项nargs\const\choices\required\metavar\dest
平常我们需要用到的就是上面那几个参数,以下内容只做了解。
- nargs表示这个参数接收几个对象,例如一个参数需要多个输入,则要指定nargs,其中通配符
?
表示1个或0个参数,*
表示0个或多个,+
表示一个或多个。
nargs = '+'
nargs = '?'
nargs = '*'
- choices表示这个参数的选项,只能从其中挑选,例如参数为性别,则只能从man、woman中选择。
add_argument('-sex',type=str,default = 'man',choices = ['man','woman'],help = 'choice your sex')
- const与nargs为?必须同时出现,且当选择了选项没有参数时会默认选择const中的内容,而没有选项时才会取default中的内容。当没有nargs时会出现
ValueError: nargs must be '?' to supply const
的错误。 - required表示这个参数必须存在,如果设置为required但没有包含这个参数的内容时会提示:
error: argument -sex is required
- metavar将写入的内容扩充到参数的帮助信息中,在显示help时也会显示。
- dest表示将获取到的参数存放进哪个变量中,例如dest='Ysex',表示可以使用
args.Ysex
访问这个参数,如果不指定,则会默认使用名字来代替。
add_argument('-sex',type=str,default = 'man',choices = ['man','woman'],help = 'choice your sex',dest='Ysex')
#如不指定dest将使用-sex中的sex默认存放,args.sex访问。
click库
01.click库安装
click是第三方开发的参数获取库,可以快捷的把一个函数修饰为命令行,相较于python自带的argparse来说,功能更加强大,也更随心所欲点,可以使用pip install click
安装。
02.click基本使用
click的命令行分为选项和参数两个部分,选项为option,参数为argument,其中option功能较多,封装了许多特殊的功能,其表示可选项,这个参数可有可无;而argument表示了必须存在的参数,按照顺序依次存入相应的变量中,直接使用xxx
访问。
03.修饰一个函数为命令行
在代码中使用@click.command()
将下方的函数改变为命令行,这样的方式显然更加简单。
import click
@click.command()
@click.option('-name',type = str , default = 'wwwaxlz' , help = 'input your name' , prompt = 'your name:')
def myfunc(name):
click.echo(name)
myfunc()
上面的代码中是option的简单用法,包括了type、default、help和prompt,其中default和help与argparse相同。不再介绍,而type方面扩展了许多的新类型,丰富了第三方库,prompt则是当这个选项没有输入时做出的提示,下面先看type的内容:
除了int / string / float 等共同的类型外,click含有许多新的类型,例如:
-
click.Choice(['yes','no'])
表示只可以在俩个内容中选择,注意'C'大写,否则会出现has no attribute 'choice'的错误 -
click.option('-password',hide_input=True, confirmation_prompt=True,prompt = 'input your pwd' , help = 'password')
,hide_input
表示输入时将会隐藏输入的内容,而confirmation
表示输入之后是否需要确认,类似于其他场景中的密码输入。对于密码click有专门的选项,@click.password_option()
可以直接完成上面的内容。 - 作为第三方的库,当然在某些方面是很方便的,例如:
import click
@click.command()
@click.option('-filen',type = click.File('rb'),prompt = 'input your filename',help = 'open file')
def myfunc(filen):
print filen.read()
myfunc()
-
这时将使用
rb
方法打开一个文件,如果一开始用户没有指定这个参数,将会提醒用户输入。
如果只需要这个文件名称或路径名称时,可以使用:
import click
@click.command()
@click.option('-filen',type = click.Path(exists=True),prompt = 'input your filename',help = 'open file')
def myfunc(filen):
clcik.echo(filen)
myfunc()
- 添加
exists=True
可以直接判断路径是否存在。
04.click.argument添加固定参数
使用argument添加参数时,参数必须存在,且没有prompt、help
等选项,当没有选中这个参数时,会直接爆出错误:Error: Missing argument "_FILEN".
既然不是选项类的参数,那么他的取值完全依靠申明的顺序,第一个申明谁,第一个参数就是谁。
例如:
@click.command()
@click.argument('filen',type = click.Path(exists=True))
@click.argument('myn',type = str , default = 'sks')
def myfunc(filen,myn):
print filen,myn
而提供的参数名称必须与函数形参取名相同,这样才能正确的获取用户的命令行输入。
显然这种方式没有选项类可完成的动作多,但是简单的脚本中完全可以使用,极简式。
总结
argparse与click完成相同的功能,但一个是python自带的库,一个是大神编写的第三方库,argparse可以为整个脚本编写参数,不需要多次申明,而click为某个函数提供参数,用户的输入都被函数获取,每个函数都需要首先注册command,在特殊的方面封装的也比较完整,值得学习!