argparse 模块详解

article/2025/8/14 19:11:59

文章目录

      • 1. argparse 模块简介
      • 2. 未使用argparse示例
      • 3. 使用argparse示例
        • 3.1 argparse简单示例
        • 3.2 argparse进阶示例
          • 3.2.1 可选参数设置
          • 3.2.2 可选参数引用名
          • 3.2.3 清除帮助中的参数名信息
          • 3.2.4 必选参数设置
          • 3.2.5 列表参数(多参数)传入设置
          • 3.2.6 互斥参数使用
          • 3.2.7 默认参数设置
      • 4. 参考文献

1. argparse 模块简介

argparse是一个用来解析命令行参数的 Python 库,它是 Python 标准库的一部分。基于 python 2.7 的stdlib 代码。

argparse模块使编写用户友好的命令行界面变得容易。程序定义了所需的参数,而 argparse 将找出如何从 sys.argv(命令行)中解析这些参数。argparse 模块还会自动生成帮助和使用消息,并在用户为程序提供无效参数时发出错误。

2. 未使用argparse示例

一般未使用到终端命令,对于一些需要变量赋值的程序,我们往往:

  • 1、直接在程序中(或配置文件)写死。
  • 2、或者利用input在命令行多次输入 这样不易多次调试及修改运行,如下就是一个示例:
import mathdef cal_vol(radius,height):vol = math.pi * pow(radius,2) * heightreturn volif __name__=='__main__':print(cal_vol(2,4))

argparse

3. 使用argparse示例

3.1 argparse简单示例

使用argparse的主要步骤:

  • 导入argparse包;
  • 创建ArgumentParser()参数对象;
  • 调用add_argument()方法往参数对象中添加参数;
  • 使用parse_args()解析添加参数的参数对象,获得解析对象;程序的其他部分需要使用命令行参数时,用解析对象.参数获取。

如下是一个简单的示例:

import math
import argparse  # 1、导入argpase包def parse_args():parse = argparse.ArgumentParser(description='Calculate cylinder volume')  # 2、创建参数对象parse.add_argument('radius', type=int, help='Radius of Cylinder')  # 3、往参数对象添加参数parse.add_argument('height', type=int, help='height of Cylinder')args = parse.parse_args()  # 4、解析参数对象获得解析对象return args# 计算圆柱体积
def cal_vol(radius, height):vol = math.pi * pow(radius, 2) * heightreturn volif __name__ == '__main__':args = parse_args()print(cal_vol(args.radius, args.height))  # 5、使用解析对象.参数获取使用命令行参数

注:此时因未指定,所以命令行参数输入默认按顺序赋值,顺序不同会造成结果不同
在这里插入图片描述在这里插入图片描述

默认命令-h可以获取添加参数时设置的帮助信息
在这里插入图片描述

  • 命令行参数输入默认按顺序赋值,顺序不同会造成结果不同;
  • 默认命令-h可以获取添加参数时设置的帮助信息;

3.2 argparse进阶示例

add_argument()方法(定义如何解析命令行参数):
在这里插入图片描述
参数解释如下:

  • name or flags - 选项字符串的名字或者列表,例如 foo 或者 -f, --foo。

  • action - 命令行遇到参数时的动作,默认值是 store。

    • – store_const,表示赋值为const;
    • – append,将遇到的值存储成列表,也就是如果参数重复则会保存多个值;
    • – append_const,将参数规范中定义的一个值保存到一个列表;
    • – count,存储遇到的次数;此外,也可以继承 argparse.Action 自定义参数解析;
  • nargs - 应该读取的命令行参数个数,可以是

    • 具体的数字,或者是?号,当不指定值时对于 Positional argument 使用 default,对于 Optional argument 使用 const
    • 或者是 * 号,表示 0 或多个参数;
    • 或者是 + 号表示 1 或多个参数。
  • const - action 和 nargs 所需要的常量值。

  • default - 不指定参数时的默认值。

  • type - 命令行参数应该被转换成的类型。默认是字符串类型。

  • choices - 参数可允许的值的一个容器。

  • required - 可选参数是否可以省略 (仅针对可选参数)。

  • help - 参数的帮助信息,当指定为 argparse.SUPPRESS 时表示不显示该参数的帮助信息.

  • metavar - 在 usage 说明中的参数名称,对于必选参数默认就是参数名称,对于可选参数默认是全大写的参数名称.

  • dest - 解析后的参数名称,默认情况下,对于可选参数选取最长的名称,中划线转换为下划线.

3.2.1 可选参数设置
import math
import argparse  # 1、导入argpase包def parse_args():parse = argparse.ArgumentParser(description='Calculate cylinder volume')  # 2、创建参数对象parse.add_argument('--radius', default=2, type=int, help='Radius of Cylinder')  # 3、往参数对象添加参数parse.add_argument('--height', default=4, type=int, help='height of Cylinder')args = parse.parse_args()  # 4、解析参数对象获得解析对象return argsdef cal_vol(radius, height):vol = math.pi * pow(radius, 2) * heightreturn volif __name__ == '__main__':args = parse_args()print(cal_vol(args.radius, args.height))  # 5、使用解析对象.参数获取使用命令行参数

通过在参数名前加 - -,设置为可选参数,如果未输入,则使用default默认值(若未设置default,则会默认赋值None),如下示例:
在这里插入图片描述

3.2.2 可选参数引用名
import math
import argparse  # 1、导入argpase包def parse_args():parse = argparse.ArgumentParser(description='Calculate cylinder volume')  # 2、创建参数对象parse.add_argument('-r', '--radius', default=2, type=int, help='Radius of Cylinder')  # 3、往参数对象添加参数parse.add_argument('-H', '--height', default=4, type=int, help='height of Cylinder')args = parse.parse_args()  # 4、解析参数对象获得解析对象return argsdef cal_vol(radius, height):vol = math.pi * pow(radius, 2) * heightreturn volif __name__ == '__main__':args = parse_args()print(cal_vol(args.radius, args.height))  # 5、使用解析对象.参数获取使用命令行参数

通过将可选参数设置引用名,可以缩短参数名,简化命令行参数输入:
在这里插入图片描述

如下:-r- -radius都可以
在这里插入图片描述
在这里插入图片描述

3.2.3 清除帮助中的参数名信息
import math
import argparse  # 1、导入argpase包def parse_args():parse = argparse.ArgumentParser(description='Calculate cylinder volume')  # 2、创建参数对象parse.add_argument('-r', '--radius', default=2, type=int, metavar='', help='Radius of Cylinder')  # 3、往参数对象添加参数parse.add_argument('-H', '--height', default=4, type=int, metavar='', help='height of Cylinder')args = parse.parse_args()  # 4、解析参数对象获得解析对象return argsdef cal_vol(radius, height):vol = math.pi * pow(radius, 2) * heightreturn volif __name__ == '__main__':args = parse_args()print(cal_vol(args.radius, args.height))  # 5、使用解析对象.参数获取使用命令行参数

如下,对比3.2.2中-h显示信息,去掉了参数名
在这里插入图片描述原因:
metavar在通过-h显示 usage
说明中的参数名称,对于必选参数默认就是参数名称,对于可选参数默认是全大写的参数名称.。这里通过设置为空一律不显示。

3.2.4 必选参数设置
import math
import argparse  # 1、导入argpase包def parse_args():parse = argparse.ArgumentParser(description='Calculate cylinder volume')  # 2、创建参数对象parse.add_argument('-r', '--radius', default=2, type=int, metavar='', required=True, help='Radius of Cylinder')  # 3、往参数对象添加参数parse.add_argument('-H', '--height', default=4, type=int, metavar='', required=True, help='height of Cylinder')args = parse.parse_args()  # 4、解析参数对象获得解析对象return argsdef cal_vol(radius, height):vol = math.pi * pow(radius, 2) * heightreturn volif __name__ == '__main__':args = parse_args()print(cal_vol(args.radius, args.height))  # 5、使用解析对象.参数获取使用命令行参数

当通过设置required=True后,无论参数是否是可选参数,都必须输入,如下示例:
在这里插入图片描述

3.2.5 列表参数(多参数)传入设置
import math
import argparsedef parse_args():parse = argparse.ArgumentParser(description='Calculate cylinder volume')parse.add_argument('-n', '--num', type=int, nargs='+', metavar='', required=True, help='a string of nums')args = parse.parse_args()return argsif __name__ == '__main__':args = parse_args()print(args.num)for i in list(args.num):print(i)

argparse

3.2.6 互斥参数使用
import math
import argparsedef parse_args():parse = argparse.ArgumentParser(description='Calculate cylinder volume')parse.add_argument('-r', '--radius', default=2, type=int, metavar='', required=True, help='Radius of Cylinder')parse.add_argument('-H', '--height', default=4, type=int, metavar='', required=True, help='height of Cylinder')group = parse.add_mutually_exclusive_group()  # 1、在参数对象中添加互斥组group.add_argument('-b', '--brief', action='store_true', help='print brief message')  # 2、在互斥组中添加参数(store_true默认当命令行未输入参数则为False,否则为True)group.add_argument('-v', '--verbose', action='store_true', help='print verbose message')args = parse.parse_args()return argsdef cal_vol(radius, height):vol = math.pi * pow(radius, 2) * heightreturn volif __name__ == '__main__':args = parse_args()volume = cal_vol(args.radius, args.height)if args.brief:print(volume)elif args.verbose:print('Volume of Cylinder with radius %s and height %s is %s' % (args.radius,args.height,volume))else:print('Volume of Cylinder is %s' % (volume))

命令行中b和v只能输入二者中的一个参数。
在这里插入图片描述

3.2.7 默认参数设置

set_defaults()可以设置一些参数的默认值

import math
import argparsedef parse_args():parse = argparse.ArgumentParser(description='Calculate cylinder volume')parse.add_argument('-r', '--radius', default=2, type=int, metavar='', required=True, help='Radius of Cylinder')parse.set_defaults(height=4)args = parse.parse_args()return argsdef cal_vol(radius, height):vol = math.pi * pow(radius, 2) * heightreturn volif __name__ == '__main__':args = parse_args()print(cal_vol(args.radius, args.height))

在这里插入图片描述

4. 参考文献

  • 原文

  • Python argparse命令行参数解析包的详细教程

  • 官方文档


http://chatgpt.dhexx.cn/article/eyPkKmqF.shtml

相关文章

python中的argparse基本用法

1、argparse是一个python模块,用途是:命令行选项、参数和子命令的解释。 2、使用步骤: 导入argparse模块,并创建解释器添加所需参数解析参数 3、用法示例: import argparse# 1.创建解释器 parser argparse.Argume…

argparse简介

一、argparse简介 argparse 模块是 Python 内置的用于命令项选项与参数解析的模块,argparse 模块可以让人轻松编写用户友好的命令行接口,能够帮助程序员为模型定义参数。 argparse定义四个步骤 导入argparse包 ——import argparse创建一个命令行解析…

绕过tp路由器管理密码_TP LINK路由器的登陆网址是什么?

旧版本的TP-Link路由器的登陆网址是:192.168.1.1;新版本的TP-Link路由器的登陆网址是:http://tplogin.cn;TP-Link迷你路由器的登陆网址是:192.168.1.253。接下来详细介绍: 一、旧版本的TP-Link路由器的登陆…

【TP5.1】Config的用法

需要读取某个一级配置的所有配置参数,可以使用 需要引入 use Config; 使用助手函数: config(app.name) config(app.); 这种类型的使用app. 这种类型的使用.code即可

TP LINK GRE L2TP介绍

(Virtual Private Network, 虚拟专用网络)是一个建立在公用网(通常是因特网)上的专用网络,但因为这个专用网络只是逻辑存在并没有实际物理线路,故称为虚拟专用网。 随着因特网的发展壮大,越来越多的数据需要在因特网上…

百信计算机管理员登录账号密码,tplogin.cn管理员密码是多少 | 192路由网

TP-Link TL-WR745N无线路由器配置简单,不过对于没有网络基础的用户来说,完成路由器的安装和无线网络密码和名称的设置,仍然有一定的困难,本文www.192luyou.com介绍TP-Link TL-WR745N无线路由器无线网络密码和名称的设置方法! TP-L…

Tplmap用法

Tplmap下载:安装包可查看我的下载资源页面 Python环境:2.7 (这一点很重要很重要很重要) Python所需要的包: PyYAML5.1.2 certifi2018.10.15 chardet3.0.4 idna2.8 requests2.22.0 urllib31.24.1 wsgiref0.1.2 (这些包只有在pyth…

TPlinker解读

参考: 关系抽取之TPLinker解读加源码分析 TPLinker 实体关系抽取代码解读 实体关系联合抽取:TPlinker TPLinker中文注释版 Tagging TPLinker模型需要对关系三元组(subject, relation, object)进行手动Tagging,过程分为三部分: &…

TP6中GatewayWorker的用法

一、参考网站 tp开发手册:https://www.kancloud.cn/manual/thinkphp6_0/1147857 workman与tp框架结合参考:http://doc2.workerman.net/work-with-other-frameworks.html 开发手册只介绍了Workman的使用方法,没有介绍GatewayWorker的使用方…

tp5框架Fastadmin中的Log日志如何去用

首先fastadmin是基于tp5的框架进行开发,在我们使用fastadmin写好接口后,接口在测试时没有任何问题,当前端进行访问时却无法进行交互,这是就可以使用tp5框架自带的Log日志; 下面就为大家介绍Log的使用: use think\Log; 在你使用的php文件下引入Log日志。 Log的使用方法: 一…

TP框架如何开启log日志

1.日志的处理工作是由系统自动进行的,在开启日志记录的情况下,会记录下允许的日志级别的所有日志信息。 其中,为了性能考虑,SQL日志级别必须在调试模式开启下有效,否则就不会记录。 系统的日志记录由核心的Think\Log类…

tplink路由器设置网址方法

tplink路由器设置网址的方法很多的用户都不知道,其实这个路由器可以通过两种方式来进行设置,十分的方便,如果你还没有完成设置不妨来试一试。 tplink路由器设置网址: 电脑: 1、首先打开浏览器,输入“192…

tp5日志

日志记录和跟踪调试。由于日志记录了所有的运行错误,因此养成经常查看日志文件的习惯,可以避免和及早发现很多的错误隐患。日志还有其他作用,用于输出一些不方便显示的调试的信息。 可以给多应用,或者前后端,分别配置…

TP Link 路由器 设置

入手某型号的TP LINK 路由器一台。希望做些定制化的设置。记录一下。 1,光猫拨号改为路由器拨号 光猫的型号是吉比特某款,其地址是192.168.1.1,此光猫没有无线。所接的路由器地址是192.168.2.1。 1,先将光猫的设置全部备份。2种…

TP5.1使用日志

日志我们在线上项目调试bug的利器,所以我们需要掌握 日志要记录的是错误信息,所以只需要将测试错误改为你需要获取的错误信息即可 1.引入think\Log这个类 2.打开log文件

TPLinker

# 笔记 1、长文本划分为短文本的时候,是以模型底层分词的个数来判断的 2、输入的X必须转换成id,输入的Y也必须转换成id,这样X输入得到的结果P才能和Y做比对,所有的模型都是围绕这个根基做转换,确认好X和Y,把…

渗透工具TPLogScan:ThinkPHP3和5日志扫描工具,提供命令行版和BurpSuite插件版,尽可能发掘网站日志信息

Git地址: r3change/TPLogScan: ThinkPHP全日志扫描工具,命令行版和BurpSuite插件版 (github.com) ThinkPHP3和5日志扫描工具,提供命令行版和BurpSuite插件版,尽可能发掘网站日志信息 命令行版 安装 git clone https://github.c…

Cadence virtuos617安装教程

Cadence virtuos安装教程 所有安装文件可在如下地址下载 链接:https://pan.baidu.com/s/1lZdRtzO1vTMHp7fmLHWGjQ?pwd=svwi 提取码:svwi下载的文件放到共享目录下。关于共享目录的设置可查看百度;并命名为Linux_space,文件名更改为Cadence.如下图 连接网络 安装虚拟机工…

Cadence 16.6安装配置教程

这里使用的是吴川斌的阿狸狗安装,傻瓜式安装,非常方便快捷 Cadence SPB 16.6安装包下载 阿狸狗下载 视频教程 双击打开阿狸狗 开始安装 其他安装

LinuxCadence学习

Linux&Cadence学习 常用指令 ls:列出当前目录下的文件ll -a:列出所有文件,包括隐藏文件ll:显示所有属性vi xxx:编辑文本;insert按键进行修改;esc退出修改;:wq!保存修改chmod 7…