【转】optparse 模块OptionParser学习记录

转自:http://blog.csdn.net/daemonpei/article/details/8295606

optparse模块主要负责命令行解析,在2.7版本改名为:argparse

不过用法差不多.

模块使用步骤:

    1 导入optionparser : import optparse

    2 创建optionparser的对象:parser = optparse.OptionParser()

    3 向optionparser对象中增加option :parser.add_option

    4 调用optionparser解析函数:(options, args) = parser.parse_args()

    5 在options中使用解析到的options,在args中使用其他的args

下面是代码样例:

    #参数解析函数,这里学习optparse模块  
    def parse_args():  
            #初始化参数解析对象  
            parser = optparse.OptionParser(USAGE)  
            #加入参数  
            parser.add_option("-H", #短参数  
                    "--host",       #长参数  
                    action="store", #参数的动作   
                    dest="host",    #参数的引用  
                    type= "string",  #参数类型  
                    help="connect host address"    #参数说明  
                    )  
            parser.add_option("-P", "--port",  
                      action="store", dest="port", type="int",  
                      help="connect host port")  
            parser.add_option("-M", "--message",  
                      action="store", dest="msg", type="string",  
                      help="send server message")  
            #调用解析方法  
            (options, args) = parser.parse_args()  
            #判断参数正确性  
            if len(args) < 3:  
                    print parser.format_help()  
                    parser.exit()  
            if not parser.host or not parser.port:  
                    print parser.format_help()  
                    parser.exit()  
            return parser  
    def StudyMain():  
            args = parse_args()  
    #############################################################  
    #main  
    #############################################################  
    if __name__ == '__main__':  
            StudyMain()  

 

需要详细说明的地方:

add_option()中参数的意义:

short option string: 为第一个参数,表示option的缩写,例如-f;

long option string: 为第二个参数,表示option的全拼,例如--file;

后面的参数皆为命名参数,命名参数为可选参数;

action=: 表示对此option的处理方式,默认值为store,表示存储option的值到解析后的options对象的成员中。action还可以有其他的值:对于bool值,使用store_true来默认存储true,使用store_false来默认存储false,store_const用来存储const设置的值到此option,append表示增加option的参数到list中,此时此option是一个list,可能包含多个值,count表示对counter增加一,callback表示调用指定的函数。所有的action值如下:

store + store_true + store_false + store_const + append + count + callback

type=:表示此option的值的类型,默认为string,可以指定为string,int, choice, float andcomplex

dest=:表示此option在经过optionparser解析后的options对象中成员的名字,默认使用long option string;

default=:表示比option的默认值;

metavar=:表示显示到help中option的默认值;

const=:当action为store_const的时候,需要设置此值;

choices=:当设置type为choices时,需要设置此值;

posted on 2013-05-13 12:04  风在竹林  阅读(369)  评论(0编辑  收藏  举报