答案:argparse通过ArgumentParser定义参数,支持类型转换、默认值、布尔开关、多值参数及子命令和参数组管理,实现灵活、健壮的命令行接口解析。

argparse
ArgumentParser
在使用
argparse
argparse
导入
argparse
创建一个
ArgumentParser
description
立即学习“Python免费学习笔记(深入)”;
import argparse # 创建ArgumentParser对象,并提供一个描述信息 parser = argparse.ArgumentParser(description='这是一个演示argparse功能的脚本。')
接下来,使用
add_argument()
-
--
比如,我们想让程序接受一个文件名作为输入,同时可以有一个可选的输出路径:
# 定义一个位置参数:输入文件
parser.add_argument('input_file', help='需要处理的输入文件路径')
# 定义一个可选参数:输出文件,默认值是'output.txt'
parser.add_argument('--output', '-o', default='output.txt',
help='处理结果的输出文件路径 (默认为 output.txt)')
# 定义一个布尔开关,用于控制是否开启详细模式
parser.add_argument('--verbose', '-v', action='store_true',
help='开启详细输出模式')当所有的参数都定义好后,调用
parse_args()
Namespace
# 解析命令行参数
args = parser.parse_args()
# 现在你可以通过args对象的属性来访问参数值了
print(f"输入文件: {args.input_file}")
print(f"输出文件: {args.output}")
if args.verbose:
print("详细模式已开启。")
else:
print("详细模式未开启。")当你运行这个脚本时,例如:
python your_script.py my_data.csv --output results.txt -v
argparse
在
argparse
add_argument
type
default
type
type
# 期望一个整数作为循环次数
parser.add_argument('--count', type=int, default=1,
help='执行操作的次数 (默认为 1)')
# 期望一个浮点数作为阈值
parser.add_argument('--threshold', type=float,
help='设置一个浮点数阈值')
# 甚至可以是一个自定义函数或类,例如转换为文件对象
def readable_file(filepath):
if not os.path.exists(filepath):
raise argparse.ArgumentTypeError(f"文件 '{filepath}' 不存在。")
if not os.path.isfile(filepath):
raise argparse.ArgumentTypeError(f"路径 '{filepath}' 不是一个文件。")
return open(filepath, 'r') # 返回文件对象
parser.add_argument('--log-file', type=readable_file,
help='指定一个存在的日志文件')当用户输入
--count 10
args.count
10
--count abc
argparse
至于
default
# 如果用户不提供--output,args.output会是'default_output.txt'
parser.add_argument('--output', default='default_output.txt',
help='输出文件路径')
# 对于必需参数(位置参数或设置了required=True的可选参数),default通常没有意义,
# 因为它们无论如何都必须被提供。如果没有设置
default
args
None
None
处理布尔开关和接受多个值的参数是
argparse
action
nargs
对于布尔开关,我们通常希望一个参数的存在与否就代表了
True
False
argparse
action='store_true'
action='store_false'
action='store_true'
True
False
action='store_false'
store_true
False
True
# 常见的详细模式开关
parser.add_argument('--verbose', '-v', action='store_true',
help='开启详细输出模式')
# 假设我们有一个默认开启的优化,可以通过参数关闭
parser.add_argument('--no-optimize', action='store_true',
help='禁用性能优化')
# 此时,如果命令行有--no-optimize,args.no_optimize为True,意味着不优化。
# 如果想让参数表示“开启优化”,可以这样定义:
parser.add_argument('--optimize', action='store_true', default=False,
help='开启性能优化 (默认关闭)')
# 这样更直观,如果命令行有--optimize,args.optimize为True。default
至于接受多个值的参数,
nargs
nargs='?'
None
default
nargs='*'
nargs='+'
argparse
nargs=N
# 接受一个可选的输出文件,但如果提供了,只能是一个
parser.add_argument('--output-file', nargs='?', default='default.txt',
help='指定一个输出文件 (可选,默认为 default.txt)')
# 接受任意数量的输入文件
parser.add_argument('input_files', nargs='*',
help='要处理的输入文件,可以有多个')
# 接受至少一个标签
parser.add_argument('--tags', '-t', nargs='+',
help='为项目添加一个或多个标签')
# 接受精确的两个坐标值
parser.add_argument('--coords', type=float, nargs=2,
help='指定两个浮点数坐标 (x y)')使用
nargs
nargs='?'
当你的命令行工具功能变得复杂,有多个相互独立的操作(比如
git add
git commit
argparse
子命令(Subparsers)
子命令允许你为不同的操作定义完全独立的参数集。这让你的工具结构清晰,用户只需记住主命令和子命令,然后每个子命令都有自己的帮助信息和参数。
实现子命令的步骤大致是这样:
ArgumentParser
add_subparsers()
add_parser()
add_argument()
一个典型的例子,比如我们想创建一个简单的文件管理工具,有
copy
delete
import argparse
parser = argparse.ArgumentParser(description='一个简单的文件管理工具')
subparsers = parser.add_subparsers(dest='command', help='可用的子命令')
# 创建 'copy' 子命令
copy_parser = subparsers.add_parser('copy', help='复制文件')
copy_parser.add_argument('source', help='源文件路径')
copy_parser.add_argument('destination', help='目标文件路径')
copy_parser.add_argument('-f', '--force', action='store_true',
help='强制覆盖目标文件')
# 创建 'delete' 子命令
delete_parser = subparsers.add_parser('delete', help='删除文件')
delete_parser.add_argument('target', help='要删除的文件路径')
delete_parser.add_argument('-r', '--recursive', action='store_true',
help='递归删除目录')
args = parser.parse_args()
if args.command == 'copy':
print(f"执行复制操作: 从 '{args.source}' 到 '{args.destination}'")
if args.force:
print("强制覆盖已启用。")
elif args.command == 'delete':
print(f"执行删除操作: '{args.target}'")
if args.recursive:
print("递归删除已启用。")
else:
parser.print_help() # 如果没有指定子命令,打印主帮助信息运行:
python my_file_tool.py copy file1.txt file2.txt -f
python my_file_tool.py delete my_dir -r
python my_file_tool.py copy --help
通过
dest='command'
args
command
参数组(Argument Groups)
当你的工具参数很多时,帮助信息可能会变得很长且难以阅读。
add_argument_group()
parser = argparse.ArgumentParser(description='一个复杂的数据处理工具')
# 常规参数
parser.add_argument('input_data', help='要处理的数据源')
# 定义一个输入相关的参数组
input_group = parser.add_argument_group('输入选项')
input_group.add_argument('--encoding', default='utf-8',
help='输入文件编码 (默认为 utf-8)')
input_group.add_argument('--skip-header', action='store_true',
help='跳过输入文件头部')
# 定义一个输出相关的参数组
output_group = parser.add_argument_group('输出选项')
output_group.add_argument('--output-format', choices=['csv', 'json', 'xml'],
default='csv', help='输出文件格式')
output_group.add_argument('--output-path', '-o', default='result.csv',
help='结果输出路径')
args = parser.parse_args()
# ... 后续处理逻辑运行
python my_data_tool.py --help
结合子命令和参数组,
argparse
以上就是Python怎么使用argparse解析命令行参数_argparse模块命令行参数解析的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号