当前位置:首页 > 技术 > 正文内容

Python命令行参数解析模块

访客 技术 2026年6月10日 1

命令行参数解析模块 在Python中,解析命令行参数通常使用sys.argvoptparse模块。 optparse模块主要用于解析脚本的命令行参数,通过预先定义好的选项来处理输入参数。 通过实例化OptionParser对象可以创建解析器(可带参数,也可不带参数),带参数时会将参数内容作为帮助信息输出。

模块简介

基本用法示例

import optparse

parser = optparse.OptionParser()  # 创建解析器对象
parser.add_option("-s", "--server", dest="server", help="指定FTP服务器IP地址")  # 定义字符串参数
parser.add_option("-P", "--port", type="int", dest="port", help="指定FTP服务器端口")  # 定义整数参数
parser.add_option("-u", "--username", dest="username", help="指定用户名")  # 定义字符串参数
parser.add_option("-p", "--password", dest="password", help="指定密码")  # 定义字符串参数

simulated_args = ['-s', '192.168.1.1', '-P', '8080', '-u', 'admin', '-p', 'secret']  # 模拟命令行参数
options, args = parser.parse_args(simulated_args)  # 解析参数

add_option方法参数说明:

  • dest:用于存储参数的属性名称,多个参数用逗号分隔
  • type:指定参数值的数据类型(如字符串、整数、浮点数)
  • help:显示在帮助信息中的说明
  • metavar:在帮助信息中显示参数的占位符名称
  • default:未指定参数时的默认值

深入解析

创建解析器对象 创建OptionParser对象时可传入以下参数:

  • usage:指定帮助信息中的使用格式
  • version:指定版本信息
  • description:帮助信息中的描述部分
  • add_help_option:是否自动添加-h/--help选项

定义参数选项 支持多种类型的动作处理:

  • store:存储参数值(需要参数)
  • store_true:存储True(无需参数)
  • store_false:存储False(无需参数)
  • append:将值添加到列表中(需要参数)
  • store_const:存储固定常量值(无需参数)
  • append_const:将常量值添加到列表中(无需参数)
  • count:统计选项出现次数(无需参数)
  • callback:自定义回调函数

操作选项

  • has_option:检查是否存在指定选项
  • remove_option:移除指定选项
  • set_default:设置默认值

选项分组 可以通过OptionGroup将相关选项分组:

group = optparse.OptionGroup(parser, title="网络设置", description="用于指定网络连接参数")
group.add_option("-H", "--host", ...)
parser.add_option_group(group)

解析参数 parse_args方法返回两个值:

  • options:包含所有已解析选项的命名空间对象
  • args:未解析的剩余参数列表

帮助信息 默认支持-h--help选项显示帮助信息:

parser = optparse.OptionParser(usage="%prog [options]", description="这是一个示例程序")
parser.add_option("-v", "--version", version="%prog 1.0", help="显示程序版本")
parser.print_help()

可以通过以下方法自定义帮助信息:

  • print_usage:输出使用格式
  • print_description:输出描述信息
  • print_version:输出版本信息

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。