1

简介

处理命令行参数对许多程序来说都是必不可少的功能。今天为大家介绍 Python 中的 argparse 模块,它是 Python 标准库中的一个模块,它可以让开发者非常简单地为程序添加命令行参数接口,包括位置参数、可选参数、标志等,并自动生成帮助信息。

2

底层原理

argparse 模块的底层实现原理是使用 Python 的元编程功能。元编程是指在编写程序时,可以用程序来修改程序本身。argparse 模块使用元编程来解析命令行参数,并生成一个 Python 对象,这个 Python 对象包含了命令行参数的所有信息。

3

使用示例

下面是一个简单的 argparse 模块的使用示例

# test.py``import argparse``   ``parser = argparse.ArgumentParser()``parser.add_argument('--name', type=str, help='The name of the person to greet.')``args = parser.parse_args()``   ``print('Hello, {}!'.format(args.name))

这个示例中,我们创建了一个 argparse.ArgumentParser 对象,并使用 add_argument() 方法添加了一个命令行参数。这个命令行参数的名称是 name,类型是 str,帮助信息是 The name of the person to greet.。然后,我们使用 parse_args() 方法解析命令行参数,并将参数存储在 args 变量中。最后,我们使用 print() 方法打印一条欢迎消息。

执行上述脚本

python test.py --name xugaoxiang.com

代码输出

Hello, xugaoxiang.com!

argparse 还提供了许多额外的功能

3.1

类型转换

可以为参数指定类型,argparse 会自动进行转换

parser.add_argument('count', type=int)

3.2

默认值

可以通过 default 设置参数的默认值

parser.add_argument('--verbosity', default=1)

如果未传入参数,则默认值为 1。

3.3

必选参数

可以通过 required 设置参数必选

parser.add_argument('--user', required=True)

如果不传入 --user 参数会报错。

3.4

选择参数

可以使用 choices 限定参数的选项

parser.add_argument('--color', choices=['red', 'green', 'blue'])

参数值只能在给定的选项中选择。

3.5

可选参数

设置 action=‘store_true’ 可以创建可选标志参数

parser.add_argument('--dry-run', action='store_true')

出现则为 True,不出现为 False。

4

注意事项

在使用 argparse 模块时,需要注意以下几点:

  • 命令行参数的名称必须唯一
  • 命令行参数的类型必须正确
  • 命令行参数的帮助信息必须简洁明了
  • 命令行参数的顺序必须正确


---------------------------END---------------------------