前言

更多内容,请访问我的 个人博客。

以前 optparse 比较火,但是在python2.7版本后,官方不再维护这个模块,转而大力支持 argparse 。

argparse 模块可以让人轻松编写用户友好的命令行接口。她可以从 sys.argv 中解析出参数,并自动生成帮助和使用手册,还能在传入无效参数时报出错误信息。

基础用法

由于是标准库,所以不需要安装,直接使用:

import argparse

parser = argparse.ArgumentParser()

# parser.add_argument("-i", "--info", action = "store", type = "string", dest = "sample_info", help = "the sample information")

args = parser.parse_args()

# print(args.sample_info)

运行以上代码,如下:

不输入参数,也没有输出结果:

$ python3 test.py

输入默认参数 --help (也可缩写为 -h ),会输出自动生成的帮助信息:

$ python3 test.py --help

# 输出:

usage: test.py [-h]

optional arguments:

-h, --help show this help message and exit

输入错误参数,会输出报错信息:

$ python3 test.py -verbose

# 输出:

usage: test.py [-h]

test.py: error: unrecognized arguments: --verbose

创建解析器

使用 argparse 的第一步是创建一个 ArgumentParser 对象,如下:

import argparse

parser = argparse.ArgumentParser(prog=None, usage=None,description=None,

epilog=None, parents=[], formatter_class=argparse.HelpFormatter, prefix_chars='-', fromfile_prefix_chars=None,

argument_default=None, conflict_handler='error', add_help=True, allow_abbrev=True)

创建一个新的 ArgumentParser 对象。所有的参数都应当作为关键字参数传入。部分参数在下面都有它更详细的描述,但简而言之,它们是:

prog - 程序的名称(默认:sys.argv[0])

usage - 描述程序用途的字符串(默认值:从添加到解析器的参数生成)

description - 在参数帮助文档之前显示的文本(默认值:无)

epilog - 在参数帮助文档之后显示的文本(默认值:无)

parents - 一个 ArgumentParser 对象的列表,它们的参数也应包含在内

formatter_class - 用于自定义帮助文档输出格式的类

prefix_chars - 可选参数的前缀字符集合(默认值:'-')

fromfile_prefix_chars - 当需要从文件中读取其他参数时,用于标识文件名的前缀字符集合(默认值:None)

argument_default - 参数的全局默认值(默认值: None)

conflict_handler - 解决冲突选项的策略(通常是不必要的)

add_help - 为解析器添加一个 -h/--help 选项(默认值: True)

allow_abbrev - 如果缩写是无歧义的,则允许缩写长选项 (默认值:True)

prog

默认情况下, ArgumentParser 对象在帮助消息中显示的程序名称是 sys.argv[0] 。若要自定义程序名,则使用 prog ,如下:

>>> parser = argparse.ArgumentParser(prog='myprogram')

>>> parser.print_help()

usage: myprogram [-h]

optional arguments:

-h, --help show this help message and exit

无论是从 sys.argv[0] 或是从 prog= 参数确定的程序名称,都可以在帮助消息里通过 %(prog)s 格式串来引用,如下:

>>> parser = argparse.ArgumentParser(prog='myprogram')

>>> parser.add_argument('--foo', help='foo of the %(prog)s program')

>>> parser.print_help()

usage: myprogram [-h] [--foo FOO]

optional arguments:

-h, --help show this help message and exit

--foo FOO foo of the myprogram program

usage

构建用法消息,如下:

>>> parser = argparse.ArgumentParser(prog='PROG', usage='%(prog)s [options]')

>>> parser.add_argument('--foo', nargs='?', help='foo help')

>>> parser.add_argument('bar', nargs='+', help='bar help')

>>> parser.print_help()

usage: PROG [options]

positional arguments:

bar bar help

optional arguments:

-h, --help show this help message and exit

--foo [FOO] foo help

description

简要描述这个程度做什么以及怎么做。在帮助消息中,这个描述会显示在命令行用法字符串和各种参数的帮助消息之间,如下:

>>> parser = argparse.ArgumentParser(description='A foo that bars')

>>> parser.print_help()

usage: argparse.py [-h]

A foo that bars

optional arguments:

-h, --help show this help message and exit

epilog

一些程序喜欢在 description 参数后显示额外的对程序的描述,如下:

>>> parser = argparse.ArgumentParser(

... description='A foo that bars',

... epilog="And that's how you'd foo a bar")

>>> parser.print_help()

usage: argparse.py [-h]

A foo that bars

optional arguments:

-h, --help show this help message and exit

And that's how you'd foo a bar

add_help

是否关闭自动生成的帮助信息,如下:

>>> parser = argparse.ArgumentParser(prog='PROG', add_help=False)

>>> parser.add_argument('--foo', help='foo help')

>>> parser.print_help()

usage: PROG [--foo FOO]

optional arguments:

--foo FOO foo help

添加参数

使用 add_argument() 方法添加参数。其中,部分参数在下面都有它更详细的描述,但简而言之,它们是:

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

action - 当参数在命令行中出现时使用的动作基本类型。

nargs - 命令行参数应当消耗的数目。

const - 被一些 action 和 nargs 选择所需求的常数。

default - 当参数未在命令行中出现时使用的值。

type - 命令行参数应当被转换成的类型。

choices - 可用的参数的容器。

required - 此命令行选项是否可省略 (仅选项可用)。

help - 一个此选项作用的简单描述。

metavar - 在使用方法消息中使用的参数值示例。

dest - 被添加到 parse_args() 所返回对象上的属性名。

name or flags

第一个传递给 add_argument() 的参数必须是一系列 flags 或者是一个简单的参数名,如下:

>>> parser.add_argument('-f', '--foo')

or

>>> parser.add_argument('bar')

action

store - 存储参数的值。这是默认的动作。如下:

>>> parser = argparse.ArgumentParser()

>>> parser.add_argument('--foo')

>>> parser.parse_args('--foo 1'.split())

Namespace(foo='1')

store_const - 存储被 const 命名参数指定的值。 store_const 动作通常用在选项中来指定一些标志。如下:

>>> parser = argparse.ArgumentParser()

>>> parser.add_argument('--foo', action='store_const', const=42)

>>> parser.parse_args(['--foo'])

Namespace(foo=42)

store_true 和 store_false - 这些是 store_const 分别用作存储 True 和 False 值的特殊用例。另外,它们的默认值分别为 False 和 True。如下:

>>> parser = argparse.ArgumentParser()

>>> parser.add_argument('--foo', action='store_true')

>>> parser.add_argument('--bar', action='store_false')

>>> parser.add_argument('--baz', action='store_false')

>>> parser.parse_args('--foo --bar'.split())

Namespace(foo=True, bar=False, baz=True)

append - 存储一个列表,并且将每个参数值追加到列表中。在允许多次使用选项时很有用。如下:

>>> parser = argparse.ArgumentParser()

>>> parser.add_argument('--foo', action='append')

>>> parser.parse_args('--foo 1 --foo 2'.split())

Namespace(foo=['1', '2'])

count - 计算一个关键字参数出现的数目或次数。例如,对于一个增长的详情等级来说有用。如下:

>>> parser = argparse.ArgumentParser()

>>> parser.add_argument('--verbose', '-v', action='count')

>>> parser.parse_args(['-vvv'])

Namespace(verbose=3)

version - 期望有一个 version= 命名参数在 add_argument() 调用中,并打印版本信息并在调用后退出。如下:

>>> import argparse

>>> parser = argparse.ArgumentParser(prog='PROG')

>>> parser.add_argument('--version', action='version', version='%(prog)s 2.0')

>>> parser.parse_args(['--version'])

PROG 2.0

python命令行参数作用_Python命令行参数解析模块argparse相关推荐

  1. python命令行参数 空格_Python 命令行参数

    Python 命令行参数 Python 提供了 getopt 模块来获取命令行参数. $ python test.py arg1 arg2 arg3 Python 中也可以使用 sys 的 sys.a ...

  2. python命令行参数 空格_Python - 命令行参数

    前言 每个脚本或者命令行程序都可以输入一些参数,通常有两种规范. 短格式,"-"号后面要紧跟一个选项字母,如果还有此选项的附加参数,可以用空格分开,也可以不分开,长度任意,可以用引 ...

  3. Python命令行参数解析模块------argparse

      首先,argparse 是python自带的命令行参数解析包,可以用来方便地读取命令行参数,当你的代码需要频繁地修改参数的时候,使用这个工具可以将参数和代码分离开来,让你的代码更简洁,适用范围更广 ...

  4. c2665 “initgraph”: 2 个重载中没有一个可以转换所有参数类型_Python 命令行之旅:深入 click 之参数篇...

    作者:HelloGitHub-Prodesire 文中涉及的示例代码,已同步更新到 HelloGitHub-Team 仓库 一.前言 在上一篇文章中,我们初步掌握了 click 的简单用法,并了解到它 ...

  5. python 拆分excel工作表_Python几行代码轻松拆分表格

    Python几行代码轻松拆分表格 作者:梅朵 微信公众号:实用办公编程技能 微信号:Excel-Python 什么?,Python几行代码竟然可以按指定轻松拆分表格? 将test.xls中的数据按地区 ...

  6. python按行拆分表格_Python几行代码轻松拆分表格

    Python几行代码轻松拆分表格 作者:梅朵 微信公众号:实用办公编程技能 微信号:Excel-Python 什么?,Python几行代码竟然可以按指定轻松拆分表格? 将test.xls中的数据按地区 ...

  7. python except用法和作用_Python保留字简单释义

    Guido van Rossum在1991年正式对外发布Python版本,现在已成为最流行的语言之一. 分别执行以下命令,查询Python语言中的保留字: import keywordkeyword. ...

  8. python参数解析模块_Python系列教程(三十七):参数解析模块argparse

    使用python写出的脚本在运行的时候,是可以传递参数的,一般会使用sys.argv[]来接收用户传的参数.但是如果要实现类似于linux命令的,比如'ls -l -t /etc/'这种比较复杂的选项 ...

  9. python字符串strip的作用_Python字符串函数strip()原理及用法详解

    Python字符串函数strip()原理及用法详解 strip:用于移除字符串头尾指定的字符(默认为空格)或字符序列.注意:该方法只能删除开头或是结尾的字符,不能删除中间部分的字符. 语法:str.s ...

最新文章

  1. 全面降低windows系统的安全隐患 (四)
  2. arcgis Manager 登陆时提示Incorrect login Information
  3. Hibernate中使用Criteria查询及注解——(HibernateUtil)
  4. Spring Cloud Alibaba —— Seata 分布式事务框架
  5. 基于Bounding Box的激光点云聚类
  6. axios传递数据到java_axios 传输与springboot后台接收数据
  7. 我用九天时间,深挖一条闲鱼诈骗黑色产业链。
  8. Axure图片不显示
  9. http 报文格式、状态码
  10. 增持风行网 百视通在下一盘很大的棋
  11. java实现文章伪原创_网站伪原创的方法 - 百度搜狗360神马网站快速排名 - OSCHINA - 中文开源技术交流社区...
  12. 适配iPhoneX、iPhoneXs、iPhoneXs Max、iPhoneXr 屏幕尺寸及安全区域
  13. Echarts经典颜色搭配
  14. OSG学习之几何图形
  15. 经常见到的几个菜谱名字
  16. 11 wifi6速率_WiFi 6是什么?现在是更换WiFi 6路由器的时候吗?
  17. 途志传媒:直播电商如何维护消费者权益?抖音推出安心购
  18. react-native 使用高德SDK取得位置信息
  19. Presto RBO之broadcast join与partitioned join类型的选择优化
  20. activiti串行多实例报错Could not execute inner activity behavior of multi instance behavior解决办法

热门文章

  1. 【渝粤题库】国家开放大学2021春2625调剂学题目
  2. php中日期选择代码,实现JS日期时间选择器
  3. 【数字信号处理】复数的另一种思考之平均风向测量(Python实现)
  4. mysql把一行保存到另一个表_MYSQL:如何复制整个行从一个表到另一个在MySQL与第二个表有一个额外的列?...
  5. centos安装盘ntfs_在CentOS下挂载NTFS格式U盘的方法
  6. linux adc测试程序,基于Qt4.7的ADC测试程序
  7. webview加载php文件,HYWebview下载自定义文件教程
  8. 最大化窗口设置_打开表格总是默认窗口最小化?适用Word、PPT等其他应用
  9. boke练习: spring boot: security post数据时,要么关闭crst,要么添加隐藏域
  10. 第2章 状态机思维与状态机变量