python3中argparse模块怎么使用?

答案:argparse是Python3解析命令行参数的标准模块,通过ArgumentParser添加参数并解析。支持位置参数、可选参数(如--verbose)、带值参数(如--port 8080)、限制取值范围(choices)和默认值,自动生成功助信息,提升脚本灵活性与专业性。

argparse 是 Python3 中用于解析命令行参数的标准模块,使用它能让你的脚本更灵活、更专业。你不需要手动处理 sys.argv,argparse 可以帮你自动解析输入,并生成帮助信息。

基本用法

先创建一个 ArgumentParser 对象,然后添加参数,最后解析它们。

import argparse

parser = argparse.ArgumentParser()

parser.add_argument('name', help='输入你的名字')

args = parser.parse_args()

print(f'Hello, {args.name}')

运行脚本:python script.py Alice,输出:Hello, Alice

添加可选参数

可选参数以 -- 开头,比如 --verbose 或 -v。

parser.add_argument('--verbose', '-v', action='store_true', help='启用详细模式')

如果命令中包含 --verbose 或 -v,args.verbose 就是 True,否则为 False。action='store_true' 表示这个参数不接收值,只是一个开关。

带值的可选参数

有些参数需要接收具体值,比如 --port 8080。

parser.add_argument('--port', type=int, default=80, help='指定端口号,默认80')

type 指定类型,default 是默认值。如果不传 --port,args.port 就是 80。

限制参数取值范围

可以用 choices 限制参数只能从几个选项中选择。

parser.add_argument('--mode', choices=['dev', 'prod', 'test'], default='dev')

如果用户输入 --mode xxx,而 xxx 不在 choices 中,程序会自动报错并提示可用选项。

位置参数与可选参数的区别

位置参数(如上面的 name)是必须提供的,除非设为可选(通过 nargs='?')。可选参数以 -- 开头,可以不传。

parser.add_argument('filename', nargs='?', default='config.txt', help='配置文件名,可选')

nargs='?' 表示这个位置参数是可选的,不提供时使用 default 值。

显示帮助和版本信息

argparse 自动支持 -h 或 --help 显示帮助。你也可以添加版本信息:

parser.add_argument('--version', action='version', version='1.0.0')

运行 python script.py --version 会输出版本号并退出。

基本上就这些。掌握 add_argument 的常用参数:name or flag, type, default, help, choices, action, nargs,就能应付大多数场景。写脚本时加上命令行支持,会让工具更易用。