(转)Python3 -- argparse模块

原文地址:http://www.cnblogs.com/arkenstone/p/6250782.html

http://blog.csdn.net/WIinter_FDd/article/details/75786410

https://oldpan.me/archives/argparse-python-order-command--------Argparse-parser模块:python快捷实现命令行操作

如果脚本很简单或临时使用,没有多个复杂的参数选项,可以直接利用sys.argv将脚本后的参数依次读取(读进来的默认是字符串格式)。比如如下名为test.py的脚本:

  1. import sys

  2.  

    print("Input argument is %s" %(sys.argv[0]))

在shell脚本中运行python test.py 可以得到Input argument is test.py 的结果。

1) 一般形式

但是大多数情况下,脚本很可能需要多个参数,而且每次参数的类型用处各不相同,那么这个时候在参数前添加标签表明参数的类型和用途便十分有用,而利用argparse模块可以很方便得实现这一目的。
同样用名为test.py的脚本举个栗子:

  1. import argparse

  2.  

  3.  

    parser = argparse.ArgumentParser(description="your script description") # description参数可以用于插入描述脚本用途的信息,可以为空

  4.  

    parser.add_argument(‘--verbose‘, ‘-v‘, action=‘store_true‘, help=‘verbose mode‘) # 添加--verbose标签,标签别名可以为-v,这里action的意思是当读取的参数中出现--verbose/-v的时候

  5.  

    # 参数字典的verbose建对应的值为True,而help参数用于描述--verbose参数的用途或意义。

  6.  

    args = parser.parse_args() # 将变量以标签-值的字典形式存入args字典

  7.  

    if args.verbose:

  8.  

    print ("Verbose mode on!")

  9.  

    else:

  10.  

    print ("Verbose mode off!")

运行python test.py后面跟了--verbose/-v的时候会输出前者,如果什么都没有会输出后者。如果输入了--verbose/-v以外的参数则会报错:unrecognized arguments
稍微提一下,action参数表示值赋予键的方式,这里用到的是bool类型;如果是‘count‘表示将--verbose标签出现的次数作为verbose的值;‘append‘表示将每次出现的该便签后的值都存入同一个数组再赋值。(嘛,一般后面两种用的比较少就不多说了)

PS:--help标签在使用argparse模块时会自动创建,因此一般情况不需要我们主动定义帮助信息。

  1. $ python test.py --help

  2.  

    usage: test.py [-h] [--verbose]

  3.  

  4.  

    your script description

  5.  

  6.  

    optional arguments:

  7.  

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

  8.  

    --verbose, -v verbose mode

2) 必需参数

这种模式用于确保某些必需的参数有输入。

parser.add_argument(‘--verbose‘, required=True, type=int)

required标签就是说--verbose参数是必需的,并且类型为int,输入别的类型会报错。

3)位置参数(positional arguments)

位置参数与sys.argv调用比较像,参数没有显式的--xxx或者-xxx标签,因此调用属性也与sys.argv相同。

  1. parser.add_argument(‘filename‘) # 输入的第一个参数赋予名为filename的键

  2.  

    args = parser.parse_args()

  3.  

    print ("Read in %s" %(args.filename))

输入python test.py test.txt则会输出Read in test.txt

此外,可以用nargs参数来限定输入的位置参数的个数,默认为1。当然nargs参数也可用于普通带标签的参数。
parser.add_argument(‘num‘, nargs=2, type=int)表示脚本可以读入两个整数赋予num键(此时的值为2个整数的数组)。nargs还可以‘*‘用来表示如果有该位置参数输入的话,之后所有的输入都将作为该位置参数的值;‘+’表示读取至少1个该位置参数。‘?‘表示该位置参数要么没有,要么就只要一个。(PS:跟正则表达式的符号用途一致。)比如用:

  1. parser.add_argument(‘filename‘)

  2.  

    parser.add_argument(‘num‘, nargs=‘*)

就可以运行python test.py text.txt 1 2
由于没有标签,所以用位置参数的时候需要比较小心。

4)输入类型

之前已经提到了用type参数就可以指定输入的参数类型。而这个type类型还可以表示文件操作的类型从而直接进行文件的读写操作。

  1. import argparse

  2.  

  3.  

    parser = argparse.ArgumentParser(description="your script description")

  4.  

    parser.add_argument(‘file‘, type=argparse.FileType(‘r‘)) # 读取文件

  5.  

    args = parser.parse_args()

  6.  

    for line in args.file:

  7.  

    print (line.strip())

写文件

  1. import argparse

  2.  

  3.  

    parser = argparse.ArgumentParser(description="your script description")

  4.  

    parser.add_argument(‘file‘, type=argparse.FileType(‘w‘)) # 写文件

  5.  

    args = parser.parse_args()

  6.  

    fp=args.file

  7.  

    fp.write(‘123345‘)

  8.  

    fp.flush()

  9.  

    fp.close()

  10.  

5)参数默认值

一般情况下会设置一些默认参数从而不需要每次输入某些不需要变动的参数,利用default参数即可实现。

parser.add_argument(‘filename‘, default=‘text.txt‘)

这个时候至直接运行python text.py就能得到Read in text.txt而不需要输入文件名了。

6)候选参数选择

表示该参数能接受的值只能来自某几个值候选值中,除此以外会报错,用choices参数即可。比如:

parser.add_argument(‘filename‘, choices=[‘test1.txt‘, ‘text2.txt‘])

参考:https://mkaz.tech/python-argparse-cookbook.html
https://docs.python.org/2/howto/argparse.html

7)使用步骤

1:import argparse

2:parser = argparse.ArgumentParser()

3:parser.add_argument()

4:parser.parse_args()

我们对这四个步骤解释一下:首先导入该模块;然后创建一个解析对象;然后向该对象中添加你要关注的命令行参数和选项,每一个add_argument方法对应一个你要关注的参数或选项;最后调用parse_args()方法进行解析;解析成功之后即可使用。

接下来我们来说明一下argparse模块中最重要的两个部分:ArgumentParser()和add_argument()。

  1. ArgumentParser(prog=None,usage=None,description=None, epilog=None, parents=[ ],

  2.  

    formatter_class=argparse.HelpFormatter, prefix_chars=’-‘,fromfile_prefix_chars=None,

  3.  

    argument_default=None, conflict_handler=’error’,add_help=True)

这些参数都有默认值,当调用parser.print_help()或者运行程序时由于参数不正确(此时python解释器其实也是调用了pring_help()方法)时,会打印这些描述信息,一般只需要传递description参数,如上所示。

下面将对ArgumentParser参数的简单说明进行中文版本的简单说明:

  1. description - 命令行帮助的开始文字,大部分情况下,我们只会用到这个参数
  2. epilog - 命令行帮助的结尾文字
  3. prog - (default: sys.argv[0])程序的名字,一般不需要修改,另外,如果你需要在help中使用到程序的名字,可以使用%(prog)s
  4. prefix_chars - 命令的前缀,默认是-,例如-f/–file。有些程序可能希望支持/f这样的选项,可以使用prefix_chars=”/”
  5. fromfile_prefix_chars - (default: None)如果你希望命令行参数可以从文件中读取,就可能用到。例如,如果fromfile_prefix_chars=’@’,命令行参数中有一个为”@args.txt”,args.txt的内容会作为命令行参数
  6. add_help - 是否增加-h/-help选项 (default: True),一般help信息都是必须的,所以不用设置啦。
  7. parents - 类型是list,如果这个parser的一些选项跟其他某些parser的选项一样,可以用parents来实现继承,例如parents=[parent_parser]
  8. 三个允许的值: # class argparse.RawDescriptionHelpFormatter 直接输出description和epilog的原始形式(不进行自动换行和消除空白的操作) # class argparse.RawTextHelpFormatter 直接输出description和epilog以及add_argument中的help字符串的原始形式(不进行自动换行和消除空白的操作) # class argparse.ArgumentDefaultsHelpFormatter 在每个选项的帮助信息后面输出他们对应的缺省值,如果有设置的话。这个最常用吧!
  9. argument_default - (default: None)设置一个全局的选项的缺省值,一般每个选项单独设置,所以这个参数用得少,不细说
  10. usage - (default: generated)如果你需要修改usage的信息(usage: PROG [-h] [–foo [FOO]] bar [bar …]),那么可以修改这个,一般不要修改。
  11. conflict_handler - 不建议使用。这个在极端情况下才会用到,主要是定义两个add_argument中添加的选项的名字发生冲突时怎么处理,默认处理是抛出异常。
  1. add_argument(name or flags…[, action][, nargs][, const][, default][, type][, choices]

  2.  

    [, required][, help][, metavar][, dest])

  1. name or flags - 指定参数的形式,想写几个写几个,不过我们一般就写两个,一个短参数,一个长参数,看下面的例子”-f”, “–file”
  2. 可选的选项,位置不固定,想怎么写就怎么写,默认是可选的 # parser.add_argument(“-f”, “–file”, help=”test test test”)
  3. 位置固定的选项,例如”prog i_am_bar”,这样子的话,i_am_bar就是bar选项的值啦,默认是必须有的 # parser.add_argument(“bar”, help=”test test test”)
  4. nargs - 指定这个参数后面的value有多少个,例如,我们希望使用-n 1 2 3 4,来设置n的值为[1, 2, 3, 4] #parser.add_argument(“-n”, “–num”, nargs=”+”, type=int) # 这里nargs=”+”表示,如果你指定了-n选项,那么-n后面至少要跟一个参数,+表示至少一个,?表示一个或0个,*0个或多个 。
  5. default - 如果命令行没有出现这个选项,那么使用default指定的默认值 #parser.add_argument(“+g”, “++gold”, help=”test test test”,default=”test_gold”)#需要prefix_chars包含”+” 。
  6. type - 如果希望传进来的参数是指定的类型(例如 float, int or file等可以从字符串转化过来的类型),可以使用 #parser.add_argument(“-x”, type=int) 。
  7. choices - 设置参数值的范围,如果choices中的类型不是字符串,记得指定type哦 #parser.add_argument(“-y”, choices=[‘a’, ‘b’, ‘d’])
  8. required - 通常-f这样的选项是可选的,但是如果required=True那么就是必须的了 #parser.add_argument(“-z”, choices=[‘a’, ‘b’, ‘d’], required=True)
  9. metavar - 参数的名字,在显示 帮助信息时才用到. # parser.add_argument(“-o”, metavar=”OOOOOO”)
  10. help - 设置这个选项的帮助信息
  11. dest - 设置这个选项的值就是解析出来后放到哪个属性中 #parser.add_argument(“-q”, dest=”world”)
  12. args = parser.parse_args(args) # 如果你没有args参数,那么就使用sys.argv,也就是命令行参数啦。有这个参数,就方便我们调试啊 。# args.world就是-q的值啦
  13. action - The basic type of action to be taken when this argument is encountered at the command line.
  14. const - A constant value required by some action and nargs selections.

最常用的参数也就是以上这些,如果有更多的需求,那么可以查看官方的API文档。

实例

下面我们将用官网的一个实例来进一步认识一下argparse。

  1. import argparse

  2.  

  3.  

    parser = argparse.ArgumentParser(description=‘Process some integers.‘)

  4.  

    parser.add_argument(‘integers‘, metavar=‘N‘, type=int, nargs=‘+‘,

  5.  

    help=‘an integer for the accumulator‘)

  6.  

    parser.add_argument(‘--sum‘, dest=‘accumulate‘, action=‘store_const‘,

  7.  

    const=sum, default=max,

  8.  

    help=‘sum the integers (default: find the max)‘)

  9.  

  10.  

    args = parser.parse_args()

  11.  

    print(args.accumulate(args.integers))

  1. $ python prog.py -h

  2.  

    usage: prog.py [-h] [--sum] N [N ...]

  3.  

  4.  

    Process some integers.

  5.  

  6.  

    positional arguments:

  7.  

    N an integer for the accumulator

  8.  

  9.  

    optional arguments:

  10.  

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

  11.  

    --sum sum the integers (default: find the max)

  1. $ python prog.py 1 2 3 4

  2.  

    4

  3.  

  4.  

    $ python prog.py 1 2 3 4 --sum

  5.  

    10

我们下面来看一段代码:

  1. # -*- coding: utf-8 -*-

  2.  

  3.  

    import argparse

  4.  

  5.  

    parser = argparse.ArgumentParser(description=‘Process some integers.‘)

  6.  

    parser.add_argument(‘integers‘, metavar=‘N‘, type=int, nargs=‘+‘,

  7.  

    help=‘an integer for the accumulator‘)

  8.  

    parser.add_argument(‘--sum‘, dest=‘accumulate‘, action=‘store_const‘,

  9.  

    const=sum, default=max,

  10.  

    help=‘sum the integers (default: find the max)‘)

  11.  

    parser.add_argument("--square", help="display a square of a given number",

  12.  

    type=int)

  13.  

  14.  

    args = parser.parse_args()

  15.  

    print(args.accumulate(args.integers), args.square**2)

在控制台dos界面下输入 python prog.py 4 5 6 –square 7

结果: 6  49

在dos窗口下键入python prog.py –sum 4 5 6 –square 7,按回车键我们来看一下运行结果:

结果:15  49

原文地址:https://www.cnblogs.com/liujiacai/p/9890495.html

时间: 2024-07-31 16:46:57

(转)Python3 -- argparse模块的相关文章

Python的Argparse模块是什么?(未完)

        近日在阅读代码的过程中遇到了Argparse模块,记得前段时间已经看了,可是过了两周现在又忘了, 看来写代码一定要钻研到底搞清楚其中原委才行,本文主要参考Python3.6系列官方文档的Argparse模块的教程. 注意:还有两个模块与Argparse功能相似,getopt和optparse. argparse基于optparse,因此在使用方面非常相似,但是不推荐使用optparse,官方文档更推荐argparse. 1.Argparse的作用 举一个小例子,在Linux系统中

python命令行解析工具argparse模块【3】

上一节,我们讲解了ArgumentParser对象,这一节我们将学习这个对象的add_argument()方法. add_argument()方法的定义了如何解析一个命令行参数,每个参数都有各自独立的设置参数. 1.name or flags add_argument()必须知道参数是可选的还是必须的位置参数,第一个传递给add_arguments的参数必须是可选参数或者是位置参数,例如,下面是可选参数. >>> parser.add_argument('-f','--foo') 而位置

python argparse模块

python argparse 模块的功能是对命令行进行解析,检查命令行是否符合预定义的格式. 使用方法: 1.导入argparse模块   import argparse 2.创建argparse对象   parser = argparse.ArgumentParser() 3.添加命令行相关参数.选项  parser.add_argument("...") 4.解析    parser.parse_args() 例一:(删除指定的zabbix screen) #!/usr/bin/

python学习之argparse模块

这里只给出常见的用法,具体原理和详细说明参考官网的说明文档: 一.简介: argparse是python用于解析命令行参数和选项的标准模块,用于代替已经过时的optparse模块.argparse模块的作用是用于解析命令行参数,例如python parseTest.py input.txt output.txt --user=name --port=8080. 二.使用步骤: 1:import argparse 2:parser = argparse.ArgumentParser() 3:par

python argparse模块解析命令行选项简单使用

argparse模块的解析命令行选项简单使用 util.py #!/usr/bin/env python # coding=utf-8 import argparse parser = argparse.ArgumentParser(prog="myprogram ",description="a test of argparse") parser.add_argument("-a",type=int,dest="start"

Python3 基础 —— 模块 Module 介绍

1.模块的作用 在交互模式下输出的变量和函数定义,一旦终端重启后,这些定义就都不存在了,为了持久保存这些变量.函数等的定义,Python中引入了模块(Module)的概念.一个Python模块其实就是一个脚本文件,具有后缀".py",例如 hello.py 就是一个模块文件名,和普通文件一样可以被永久保存在本地存储磁盘中. 2.模块的内容 Python模块中存放的是一些程序代码,例如,变量定义.函数定义或是代码语句.下面是hello.py模块的内容,其中有一个变量 a,一个函数 fun

学习python argparse模块下载安装和使用

Python中argparse模块已经替代以前的optparse模块,常被用来实现命令行参数和选项的解析作用. 位置参数: 从一个最基本的程序开始(它并没有实现什么现实的功能): import argparseparser = argparse.ArgumentParser()parser.parse_args() 下面是运行之后的结果: $ python prog.py$ python prog.py --helpusage: prog.py [-h]optional arguments: 

Python3 logging 模块

Python3 logging模块 日志模块: 用于便捷记录日志且线程安全的模块 CRITICAL = 50 FATAL = CRITICAL ERROR = 40 WARNING = 30 WARN = WARNING INFO =20 DEBUG = 10 NOTSET = 0 设置为debug import logging 1 import logging 2 logging.debug('debug') 3 logging.info('info') 4 logging.warning('

Python中的argparse模块

argparse是argument(参数)和parser(解析器)的缩写 argparse模块是向.py文件传递参数.如果你想直接运行.py文件,同时向文件中传递参数,就要使用这个模块. 使用这个模块的步骤分以下几步: 1 引入模块 import argparse 2 创建解析对象parser parser = argparse.ArgumentParser() 3 向对象中添加参数 parser.add_argument(name or flag, nargs= , action= ,type