推荐使用argparse解析命令行参数,它功能完整且用户友好,支持位置与可选参数、子命令、类型检查及自动生成帮助;getopt适用于简单场景或旧代码兼容;optparse已弃用;第三方库click采用装饰器风格,适合复杂CLI应用;fire由Google开发,可快速将函数或类转为命令行接口,适合原型开发。日常推荐argparse,大型项目用click,快速调试选fire。

Python 提供了多个用于解析命令行参数的模块,各有特点,适用于不同场景。以下是常用的几种:
1. argparse(推荐使用)
这是目前最常用、功能最完整的标准库模块,适合构建用户友好的命令行工具。 支持位置参数、可选参数、子命令、默认值、类型检查、帮助信息自动生成等。示例:
立即学习“Python免费学习笔记(深入)”;
import argparse
parser = argparse.ArgumentParser(description='处理文件')
parser.add_argument('--input', '-i', type=str, required=True, help='输入文件路径')
parser.add_argument('--verbose', '-v', action='store_true', help='启用详细输出')
args = parser.parse_args()
print(args.input)
2. getopt
这是较早的标准库模块,接口类似 C 语言的 getopt(),适合简单场景或需要兼容旧代码的情况。 只支持短选项(-f)和长选项(--file),需要手动处理异常和逻辑。示例:
立即学习“Python免费学习笔记(深入)”;
import getopt, sys
opts, args = getopt.getopt(sys.argv[1:], 'i:v', ['input=', 'verbose'])
for opt, val in opts:
if opt in ('-i', '--input'):
input_file = val
3. optparse(已弃用)
这是 argparse 的前身,在 Python 2 中广泛使用,但在 Python 3.2 后已被标记为弃用,不建议新项目使用。 功能不如 argparse 强大,且不再维护。4. 第三方库:click
非常流行的第三方命令行库,采用装饰器风格,代码简洁,适合构建复杂 CLI 工具。 支持嵌套命令、自动帮助、参数类型丰富、提示交互等。示例:
立即学习“Python免费学习笔记(深入)”;
import click
@click.command()
@click.option('--name', prompt='你的名字')
def hello(name):
click.echo(f'Hello {name}!')
if __name__ == '__main__':
hello()
5. 第三方库:fire
Google 开发的库,可以快速将任意 Python 对象变成命令行接口,几乎无需配置。 适合快速暴露函数或类为 CLI,调试和脚本工具特别方便。示例:
立即学习“Python免费学习笔记(深入)”;
import fire基本上就这些。日常开发中,argparse 是标准选择,click 更适合大型 CLI 应用,fire 适合快速原型。根据需求选合适的就行。
def greet(name, times=3):
for _ in range(times):
print(f'Hello {name}')
if __name__ == '__main__':
fire.Fire(greet)










