argparse用于编写命令行接口。argparse利用引数Argument改变程序中的变量。
示例
#videos.py
import argparse
parser = argparse.ArgumentParser(description='Videos to images')
parser.add_argument('indir', type=str, help='Input dir for videos')
parser.add_argument('outdir', type=str, help='Output dir for image')
args = parser.parse_args()
print(args.indir)
执行python video.py /videos /images
注意:传递变量时候,不必对/videos和/images添加引号。
每一次调用parser.add_argument将创建一个位置参数。在python中位置参数的顺序很重要,命令行中第一个值传递给第一个
位置参数,第二个值传递给第二个位置参数。
当用户给程序提供无效参数时,argparse模块还会自动生成帮助和使用消息并发出错误。例如,直接在终端执行
python video.py将会得到错误:videos.py: error: the following arguments are required: indir, outdir.
可选参数和位置参数的创建类似,除了他们在名字开头有'--'(或者是’-‘和一个额外的缩写字母)。例如,
你可以创建一个可选参数通过
# my_example.py
import argparse
parser = argparse.ArgumentParser(description='My example explanation')
parser.add_argument(
'--my_optional',
default=2,
help='provide an integer (default: 2)'
)
my_namespace = parser.parse_args()
print(my_namespace.my_optional)
可选参数可以有默认值,执行python my_example.py输出2,执行python my_example.py --my_optional=3输出3
add_argument() 方法定义如何解析命令行参数:
ArgumentParser.add_argument(name or flags...[, action][, nargs][, const][, default][, type][, choices][, required][, help][, metavar][, dest])
每个参数解释如下:
argparse.SUPPRESS
时表示不显示该参数的帮助信息.具体示例参考https://www.jianshu.com/p/fef2d215b91d