news 2026/6/9 18:52:39

Python标准库介绍

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python标准库介绍

argparse模块

argparse是 Python 标准库中的一个模块(自 Python 2.7 和 3.2 起内置),用于解析命令行参数和选项。功能强大、使用广泛,是编写命令行工具的首选。


一、基本用途

argparse的主要作用是:

  • 解析用户在命令行中传入的参数;
  • 自动生成帮助信息(--help);
  • 对输入参数进行类型检查、范围限制等;
  • 支持位置参数(positional arguments)和可选参数(optional arguments)。

二、基本用法示例

importargparse# 创建解析器parser=argparse.ArgumentParser(description='计算两个数的和')# 添加位置参数parser.add_argument('a',type=int,help='第一个整数')parser.add_argument('b',type=int,help='第二个整数')# 添加可选参数parser.add_argument('-v','--verbose',action='store_true',help='是否显示详细信息')# 解析参数args=parser.parse_args()# 使用参数result=args.a+args.bifargs.verbose:print(f'{args.a}+{args.b}={result}')else:print(result)

运行示例:

$ python script.py358$ python script.py35-v3+5=8$ python script.py --help usage: script.py[-h][-v]a b 计算两个数的和 positional arguments: a 第一个整数 b 第二个整数 options: -h, --help show thishelpmessage andexit-v, --verbose 是否显示详细信息

三、常用参数说明

参数说明
name or flags'name'(位置参数)或'-f', '--file'(可选参数)
type指定参数类型,如int,float,str,或自定义函数
default默认值
help帮助信息
action参数行为,如'store_true'(无参开关)、'append'(多次出现收集为列表)等
choices限定可选值,如choices=['red', 'blue']
nargs指定参数数量,如'*'(0或多个)、'+'(1或多个)、'?'(0或1个)
required对可选参数设为True表示必须提供(仅用于可选参数)

四、高级功能示例

1. 子命令(subcommands)

适用于类似git commitgit push这样的多命令工具:

parser=argparse.ArgumentParser()subparsers=parser.add_subparsers(dest='command')# 子命令:addadd_parser=subparsers.add_parser('add',help='加法')add_parser.add_argument('x',type=int)add_parser.add_parser('y',type=int)# 子命令:mulmul_parser=subparsers.add_parser('mul',help='乘法')mul_parser.add_argument('x',type=int)mul_parser.add_argument('y',type=int)args=parser.parse_args()ifargs.command=='add':print(args.x+args.y)elifargs.command=='mul':print(args.x*args.y)

2. 互斥参数组

确保某些参数不能同时出现:

group=parser.add_mutually_exclusive_group()group.add_argument('--quiet',action='store_true')group.add_argument('--verbose',action='store_true')

未完待续…

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 17:47:10

远程调试Miniconda异步任务执行状态

远程调试 Miniconda 异步任务执行状态 在深度学习和数据科学项目中,一个常见的场景是:你在本地写好了训练脚本,准备在远程服务器上启动长达数小时甚至数天的模型训练任务。你提交了任务,打开浏览器想看看进展——结果发现日志停滞…

作者头像 李华
网站建设 2026/6/9 18:44:42

宝塔面板v7.7.0离线安装终极教程:内网环境一键部署指南

宝塔面板v7.7.0离线安装终极教程:内网环境一键部署指南 【免费下载链接】btpanel-v7.7.0 宝塔v7.7.0官方原版备份 项目地址: https://gitcode.com/GitHub_Trending/btp/btpanel-v7.7.0 宝塔面板v7.7.0离线安装方案为内网服务器管理提供完美解决方案。在完全隔…

作者头像 李华
网站建设 2026/6/9 18:40:23

Anaconda Prompt替代方案:Miniconda终端配置

Miniconda-Python3.9 终端配置:轻量高效的 Python 环境实践 在数据科学和人工智能项目中,环境管理常常成为开发效率的隐形瓶颈。你是否曾遇到过这样的场景:刚接手一个 GitHub 上的开源项目,requirements.txt 一拉,pip …

作者头像 李华
网站建设 2026/6/5 15:19:28

Simple Comic:Mac上的终极免费漫画阅读器解决方案

Simple Comic:Mac上的终极免费漫画阅读器解决方案 【免费下载链接】Simple-Comic OS X comic viewer 项目地址: https://gitcode.com/gh_mirrors/si/Simple-Comic 作为一名Mac用户和漫画爱好者,你是否曾经为寻找一款真正简洁高效的漫画阅读器而烦…

作者头像 李华
网站建设 2026/6/9 18:34:25

ImTip:让你的输入法状态一目了然,工作效率翻倍提升

ImTip:让你的输入法状态一目了然,工作效率翻倍提升 【免费下载链接】ImTip 项目地址: https://gitcode.com/gh_mirrors/im/ImTip 还在为输入法状态切换烦恼吗?明明想输入中文却打出了英文,需要大写却按成了小写&#xff1…

作者头像 李华
网站建设 2026/6/7 22:20:45

Step-Audio-Tokenizer语音编码部署完全手册:从零到工业级API实战

Step-Audio-Tokenizer语音编码部署完全手册:从零到工业级API实战 【免费下载链接】Step-Audio-Tokenizer 项目地址: https://ai.gitcode.com/StepFun/Step-Audio-Tokenizer 还在为语音模型的高昂部署成本头疼吗?🤔 面对复杂的依赖冲突…

作者头像 李华