码迷,mamicode.com
首页 > 编程语言 > 详细

python——optparse模块

时间:2020-05-10 19:02:19      阅读:71      评论:0      收藏:0      [点我收藏+]

标签:ade   stat   hhhh   布尔   xxx   帮助信息   常用   内容   head   

python——optparse模块

参考链接

基本说明

optparse,是一个更够让程序设计人员轻松设计出简单明了、易于使用、符合标准的Unix命令例程式的Python模块,生成使用和帮助信息。

参数说明

  • dest:用于保存输入的临时变量,其值通过options的属性进行访问,存储的内容是dest之前输入的参数,多个参数用逗号分隔
  • type: 用于检查命令行参数传入的参数的数据类型是否符合要求,有 string,int,float 等类型
  • help:用于生成帮助信息
  • default: 给dest的默认值,如果用户没有在命令行参数给dest分配值,则使用默认值

函数说明

  • parse = optparse.OptionParser(usage, version="%prog 版本解释")
    
  • parse.add_option(‘-a‘, ‘--aaa‘, dest=‘aaa‘, help=‘aaa,aaa‘)
    
  • group1 = optparse.OptionGroup(parse, "fff", ‘dddd‘)
    
  • group1.add_option(‘-s‘, ‘--server‘, dest=‘hhhh‘, help="dddd")
    
  • parse.add_option_group(group1)
    
  • options, args = parse.parse_args()
    

简单使用

# coding = utf-8

from optparse import OptionParser
from optparse import OptionGroup

usage = ‘Usage: %prog [options] arg1 arg2 ...‘

parser = OptionParser(usage,version=‘%prog 1.0‘)
#通过OptionParser类创建parser实例,初始参数usage中的%prog等同于os.path.basename(sys.argv[0]),即
#你当前所运行的脚本的名字,version参数用来显示当前脚本的版本。

‘‘‘
添加参数,-f、--file是长短options,有一即可。

action用来表示将option后面的值如何处理,比如:
XXX.py -f test.txt
经过parser.parse_args()处理后,则将test.txt这个值存储进-f所代表的一个对象,即定义-f中的dest
即option.filename = ‘test.txt‘
action的常用选项还有store_true,store_false等,这两个通常在布尔值的选项中使用。

metavar仅在显示帮助中有用,如在显示帮助时会有:
-f FILE, --filename=FILE    write output to FILE
-m MODE, --mode=MODE  interaction mode: novice, intermediate, or expert
                        [default: intermediate]
如果-f这一项没有metavr参数,则在上面会显示为-f FILENAME --filename=FILENAME,即会显示dest的值

defalut是某一选项的默认值,当调用脚本时,参数没有指定值时,即采用default的默认值。
‘‘‘

parser.add_option(‘-f‘,‘--file‘,
                  action=‘store‘,dest=‘filename‘,
                  metavar=‘FILE‘,help=‘write output to FILE‘)

parser.add_option(‘-m‘,‘--mode‘,
                  default = ‘intermediate‘,
                  help=‘interaction mode:novice,intermediate,or expert [default:%default]‘)
parser.add_option(‘-v‘,‘--verbose‘,
                  action=‘store_true‘,dest=‘verbose‘,default=True,
                  help=‘make lots of noise [default]‘)

parser.add_option(‘-q‘,‘--quiet‘,
                  action=‘store_false‘,dest=‘verbose‘,
                  help="be vewwy quiet (I‘m hunting wabbits)")

group = OptionGroup(parser,‘Dangerous Options‘,
                    ‘Caution: use these options at your own risk.‘
                    ‘It is believed that some of them bite.‘)
#调用OptionGroup类,定制以组显示的option

group.add_option(‘-g‘,action=‘store_true‘,help=‘Group option.‘)
#添加option
parser.add_option_group(group)
#将刚定制的groupoption加入parser中

group = OptionGroup(parser,‘Debug Options‘)
group.add_option(‘-d‘,‘--debug‘,action=‘store_true‘,
                 help=‘Print debug information.‘)
group.add_option(‘-s‘,‘--sql‘,action=‘store_true‘,
                 help=‘Print all SQL statements executed‘)
group.add_option(‘-e‘,action=‘store_true‘,help=‘Print every action done‘)
parser.add_option_group(group)

(options,args) = parser.parse_args()
#解析脚本输入的参数值,options是一个包含了option值的对象
#args是一个位置参数的列表

python.exe xxx.py --help 显示结果如下:

Usage: test_optparse.py [options] arg1 arg2 ...

Options:
  --version             show program‘s version number and exit
  -h, --help            show this help message and exit
  -f FILE, --file=FILE  write output to FILE
  -m MODE, --mode=MODE  interaction mode:novice,intermediate,or expert
                        [default:intermediate]
  -v, --verbose         make lots of noise [default]
  -q, --quiet           be vewwy quiet (I‘m hunting wabbits)

  Dangerous Options:
    Caution: use these options at your own risk.It is believed that some
    of them bite.

    -g                  Group option.

  Debug Options:
    -d, --debug         Print debug information.
    -s, --sql           Print all SQL statements executed
    -e                  Print every action done

python——optparse模块

标签:ade   stat   hhhh   布尔   xxx   帮助信息   常用   内容   head   

原文地址:https://www.cnblogs.com/tomyyyyy/p/12864412.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!