• Python3中使用argparse模块解析命令行参数


          argparse是Python的一个标准模块,用于解析命令行参数,即解析sys.argv中定义的参数。实现在:https://github.com/python/cpython/blob/main/Lib/argparse.py

          argparse模块还会自动生成帮助和使用信息,即在最后加-h或--help。当用户输入的参数无效时,会触发error,并给出出错原因。

    1. python test_argparse.py -h
    2. python test_argparse.py --help

          使用argparse的步骤:

          1.创建解析器:argparse.ArgumentParser(),ArgumentParser是个class,构造它时有很多参数可以指定,若不指定这些参数都使用默认值,如description=None:此python程序功能的描述;add_help=True:添加-h/--help选项

    parser = argparse.ArgumentParser(description="test argparse's use", add_help=True)

          2.添加参数:parser.add_argument(*args, **kwargs):*args允许函数接受任意数量的位置参数(positional arguments),**kwargs允许函数接受任意数量的关键字参数。Python不允许位置参数跟在关键字参数之后。

          (1).name or flags:一个名字,位置参数(positional arguments),不带有"-"或"--",如foo;一个可选字符串的列表,如-f, --foo。当parse_args()被调用时,可选参数会以"-"前缀识别,剩下的参数则会被假定为位置参数。

    1. parser.add_argument("integers", metavar="N", type=int, nargs="+", help="an integer for the accumulator") # positional argument
    2. parser.add_argument("--sum", dest="accumulate", action="store_const", const=sum, default=max, help="sum the integers(default: find the max)") # optional argument
    3. args = parser.parse_args()
    4. print(args.accumulate(args.integers)) # print either the sum or the max of the command-line integers

         

           (2).action:ArgumentParser对象将命令行参数与action相关联。这些action可以做与它们相关联的命令行参数的任何事,尽管大多数action只是简单的向parse_args()返回的对象上添加一个属性。action关键字参数指定应如何处理命令行参数。默认的action是"store",存储参数的值。

          (3).nargs:此关键字参数将不同数量的命令行参数与单个操作相关联。

          "?":如果不存在命令行参数,则会使用default值;还有一种情况,"-"选项字符串存在,但后面没有跟着命令行参数,则会使用const值。

          "*":所有命令行参数都收集到一个列表中。

          "+":与"*"类似,但至少存在一个命令行参数,否则会产生错误消息。

    1. parser.add_argument('--foo', nargs='?', const='c', default='d')
    2. args = parser.parse_args()
    3. print(args.foo) # print 'c' or 'd' or command-line input

         

           (4).const:此关键字参数用于保存不是从命令行中读取但被各种ArgumentParser操作所需的常量值。对'store_const'和'append_const' action,const关键字参数必须给出;对其它action,默认为None。

          (5).default:此关键字参数用于在命令行参数不存在应使用的值,默认值为None。

          (6).type:此关键字参数允许执行任何必要的类型检查和类型转换。

          (7).choices:某些命令行参数应当从一组受限值中选择,这些可以通过将容器对象作为choices关键字参数传递给add_argument()来处理。当执行命令行解析时,参数值将被检查,如果参数不是可接受的值之一将触发错误消息。

    1. parser.add_argument('addr', type=str, choices=['csdn', 'github'])
    2. args = parser.parse_args()
    3. print("addr:", args.addr)

         

           (8).required:通常,argparse模块假定"-f"和"--bar"等标志表示可选参数,在命令行中始终可以省略这些参数。要让一个选项成为必需的,则可以将required关键字参数指定为True。

          (9).help:包含参数简短描述的字符串。通常在命令行中使用-h或--help时,这些help描述将与每个参数一起显示。

          (10).metavar:当ArgumentParser生成帮助消息时,它需要某种方式来引用每个预期的参数。默认情况下,ArgumentParser对象使用dest值作为每个对象的"name"。默认情况下,对于位置参数action,直接使用dest值,对于可选参数action,dest值是大写的。可以使用metavar来指定一个替代名称。

    1. parser.add_argument('--foo')
    2. parser.add_argument('--bar', metavar='XXX')
    3. args = parser.parse_args()

         

          (11).dest:大多数ArgumentParser操作都会添加一些值作为parse_args()返回的对象的一个属性。此属性的名称由add_argument()的dest关键字参数确定。

          3.解析参数:parser.parse_args(),将参数字符串转换为对象并将其设为命名空间的属性,返回带有成员的命名空间。

          更多介绍参考:https://docs.python.org/zh-cn/3.8/library/argparse.html

          GitHubhttps://github.com/fengbingchun/Python_Test

  • 相关阅读:
    49 - 多态的概念和意义
    Android项目目录结构和资源管理
    这几款文档笔记工具,你习惯用哪个?
    为什么通过一致性正则化方法就可以避免将所有未标记数据集分配给同一类?
    《痞子衡嵌入式半月刊》 第 51 期
    【CV知识点扫盲】|激活函数篇
    Java拼图游戏
    Java中的线程池
    如何处理消费过程中的重复消息
    Java输入输出之文件字符IO流之文件加密
  • 原文地址:https://blog.csdn.net/fengbingchun/article/details/126909875