Python中强大的选项处理模块。
示例
#!/usr/bin/pythonfrom optparse import OptionParser
parser = OptionParser()
parser.add_option(\"-f\", \"--file\", dest=\"filename\",
help=\"write report to FILE\", metavar=\"FILE\")
parser.add_option(\"-q\", \"--quiet\",
action=\"store_false\", dest=\"verbose\", default=True,
help=\"don\'t print status messages to stdout\")
(options, args) = parser.parse_args()
print options.filename,options.verbose
将上面代码保存到文件option1.py(名字随便),添加执行权限并运行:
./option1.py
./option1.py -f
./option1.py -f foo.txt
./option1.py -f foo.txt -q
./option1.py -qffoo.txt # 注意这个和下面对比
./option1.py -fqfoo.txt
./option1.py --file foo.txt
./option1.py --quiet
./option1.py -h # -h和--help默认情况optpars自动处理。
./option1.py --help
查看输出结果,稍稍思考就有所的了。
加载模块
要使用 OptionParser 模块,需要在Python程序中导入:
from optparse import OptionParser
生成 OptionParser 实例
首先需要生成一个实例,以后的操作都是操作这个实例,相当于分配了一段内存空 间。不然无处可以操作,类似C中的结构说明。不过Python是面向”对象“的语言。对 象的属性比结构多很多,可操作性更强,后面我们会介绍在生成 OptionParser 对象 的时候可以传递的一些参数。
usage = \"usage: %prog [options] arg\" # 定义字符串
parser = OptionParser(usage) # 传递一个字符串参数
OptionParser 不要求一定要传递参数,不过传递一些参数,可以方便程序使用。
OptionParser(usage=\"%prog [-f] [-g]\",version=\"%prog 1.0\")
# %prog 在这里会自动替换为程序名字
# usage 可以打印用法
# version 在使用 %prog --version 的时候输出版本信息
使用add_option添加命令行参数
parser.add_option(\"-f\", \"--file\", dest=\"filename\",
help=\"read data from FILENAME\")
parser.add_option(\"-v\", \"--verbose\",
action=\"store_true\", dest=\"verbose\")
parser.add_option(\"-q\", \"--quiet\",
action=\"store_false\", dest=\"verbose\")
最后调用parse_args()解析命令行参数
(options, args) = parser.parse_args()
可以传递一个参数列表给parse_args(),否则,默认使用命令行参数 (sys.argv[1:])。parse_args()返回两个值:
-
options , 这是一个对象(optpars.Values),保存有命令行参数值。只要知道 命令行参数名,如file,就可以访问其对应的值:options.file。
-
args , 一个由 positional arguments 组成的列表
parse_args()方法的参数
action
action是parse_args()方法的参数之一,指示optparser解析参数时候该如何处理。 action有一组固定的值可以选择,默认是\'store\',表是将命令行参数值保存到 options对象里。
parser.add_option(\"-f\",\"--file\",
action=\"store\",type=\"string\",dest=\"filename\")
args=[\"-f\",\"foo.txt\"]
(options,args)=parser.parse_args(args)
print options.filename
上面程序会输出\"foo.txt\"
action的值有:store,store_true,store_false,store_const,append,count,callback.
type
type的默认值是\"string\",也可以是\"int\"\"float\"等。
dest
如果没有指定dest参数,将用命令行的参数名来对options对象的值进行存取。
store的形式
store可以为 store_true 和 store_false 两种形式。用于处理命令行参数后面不 带值的情况。如 -v, -q 等命令行参数:
parser.add_option(\"-v\",action=\"store_true\",dest=\"verbose\")
parser.add_option(\"-q\",action=\"store_false\",dest=\"verbose\")
当解析到 -v ,options.verbose值为True,解析到 -q , 值为 False。注意,这里 顺序解析,所以如果有 -vq,最终的值还是False。
default — 设置默认值
# Python学习交流QQ群:489111204
parser.add_option(\"-f\",\"--file\",
action=\"store\",
dest=\"filename\",
default=\"foo.txt\")
parser.add_option(\"-v\",
action=\"store_true\",
dest=\"verbose\",
default=True)
help — 指定帮助文档
parser.add_option(\"-f\", \"--filename\",
metavar=\"FILE\",
help=\"write output to FILE\"),
optparse解析到 -h 或者 —help 命令行参数时,调用 parser.print_help()输出 程序帮助信息。help字段很有用。
metavar — 提示用户期望参数
Group — 给参数分组
group = OptionGroup(parser, ``Dangerous Options\",
``Caution: use these options at your own risk.\"
``It is believed that some of them bite.\")
group.add_option(``-g\", action=\"store_true\", help=\"Group option.\")
parser.add_option_group(group)
来源:https://www.cnblogs.com/python1111/p/17030994.html
本站部分图文来源于网络,如有侵权请联系删除。