**argparse的基本用法**
该库的介绍:
argparse 是python自带的命令行参数解析包,可以用来方便地读取命令行参数,当你的代码需要频繁地修改参数的时候,使用这个工具可以将参数和代码分离开来,让你的代码更简洁,适用范围更广。
argparse调用框架
import argparse
def get_args():
parser=argparse.ArgumentParser()
parser.add_argument("--name",default="LiMing", type=str,
help="the setting of name")
......
args = parser.parse_args()
return args
if __name__ == '__main__':
args = get_args()
name = args.name
print("My name is {}".format(name))
执行命令:
$ python print_name.py
My name is LiMing
$ python print_name.py --name Wang
My name is Wang
argparse的用法:
import argparse
def get_parser():
parser = argparse.ArgumentParser(description="Demo of argparse")
parser.add_argument('--name', default='Great')
return parser
if __name__ == '__main__':
parser = get_parser()
args = parser.parse_args()
print('Hello {}'.format(name))
在命令行执行如下命令:
$ python print_name.py --name Wang
Hello Wang
上面的代码段中,我们显示引入了argparser包,然后通过argparser.ArgumentParser函数生成argparser对象,其中这个函数的description函数表示在命令行显示帮助信息的时候,这个程序的描述信息。之后我们通过对象的add_argument函数来增加参数。这里我们只增加了一个–name的参数,然后后面的default参数表示如果没提供参数,我们默认采用的值。即如果像下面这样执行命令:
$ python print_name.py
则输出是:
$ Hello Great
最后我们通过argpaser对象的parser_args函数来获取所有参数args,然后通过args.name的方式得到我们设置的–name参数的值,可以看到这里argparse默认的参数名就是–name形式里面–后面的字符串。整个流程就是这样,下面我们详细讲解add_argument函数的一些最常用的参数,使得你看完这个教程之后,能完成科研和工作中的大部分命令解析任务。
default:没有设置值情况下的默认参数
如同上例中展示的,default表示命令行没有设置该参数的时候,程序中用什么值来代替。
required: 表示这个参数是否一定需要设置
如果设置了required=True,则在实际运行的时候不设置该参数将报错:
…
parser.add_argument(’-name’, required=True)
…
则运行下面的命令会报错:
$ python print_name.py
usage: print_name.py [-h] --name NAME
print_name.py: error: argument --name is required
#name: square.py
import argparse
def get_parser():
parser = argparse.ArgumentParser(
description='Calculate square of a given number')
parser.add_argument('-number', type=int)
return parser
if __name__ == '__main__':
parser = get_parser()
args = parser.parse_args()
res = args.number ** 2
print('square of {} is {}'.format(args.number, res))
执行:
$ python square.py -number 5
square of 5 is 25
import argparse
def get_parser():
parser = argparse.ArgumentParser(
description='choices demo')
parser.add_argument('-arch', required=True, choices=['alexnet', 'vgg'])
return parser
if __name__ == '__main__':
parser = get_parser()
args = parser.parse_args()
print('the arch of CNN is '.format(args.arch))
如果像下面这样执行会报错:
$ python choices.py -arch resnet
usage: choices.py [-h] -arch {alexnet,vgg}
choices.py: error: argument -arch: invalid choice: ‘resnet’ (choose from ‘alexnet’, ‘vgg’)
因为我们所给的-arch参数resnet不在备选的choices之中,所以会报错
下面是个例子:
import argparse
def get_parser():
parser = argparse.ArgumentParser(
description='help demo')
parser.add_argument('-arch', required=True, choices=['alexnet', 'vgg'],
help='the architecture of CNN, at this time we only support alexnet and vgg.')
return parser
if __name__ == '__main__':
parser = get_parser()
args = parser.parse_args()
print('the arch of CNN is '.format(args.arch))
在命令行加-h或–help参数运行该命令,获取帮助信息的时候,结果如下:
$ python help.py -h
usage: help.py [-h] -arch {alexnet,vgg}
choices demo
optional arguments:
-h, --help show this help message and exit
-arch {alexnet,vgg} the architecture of CNN, at this time we only support
alexnet and vgg.
dest:设置参数在代码中的变量名
argparse默认的变量名是–或-后面的字符串,但是你也可以通过dest=xxx来设置参数的变量名,然后在代码中用args.xxx来获取参数的值。
nargs: 设置参数在使用可以提供的个数
使用方式如下:
parser.add_argument(’-name’, nargs=x)
其中x的候选值和含义如下:
值 含义
N 参数的绝对个数(例如:3)
‘?’ 0或1个参数
‘*’ 0或所有参数
‘+’ 所有,并且至少一个参数
如下例子:
import argparse
def get_parser():
parser = argparse.ArgumentParser(
description='nargs demo')
parser.add_argument('-name', required=True, nargs='+')
return parser
if __name__ == '__main__':
parser = get_parser()
args = parser.parse_args()
names = ', '.join(args.name)
print('Hello to {}'.format(names))
执行命令和结果如下:
$ python nargs.py -name A B C
Hello to A, B, C