使用的时候呢,首先是import argparse,然后可以创建一个parser,parser=argparse.ArgumentParser,下面就到了指定命令行参数格式的时候了。使用add_argument可以增加命令行选项,比如-f,-i,-o什么的。在使用add_argument的时候必须指定命令行的格式,是否是必须的,等等。比如下面的使用方式:
parser.add_argument(“-i”,required=True,dest=”input”,mentavar=“INPUT”,help=“输入文件”,nargs=“+”)。下面对这里面使用的各种参数进行解释,当然这里我
只使用了一部分的参数,更详细的可以自己去python的帮助里查找了。python自动增加了一个-h的选项,用来对这个程序的用法进行说明。
“-i",表示选项(optional arguments),另外一个就是positional arguments,可惜我不知道是什么意思。
dest=”input“,表示引用命令行解析的结果时可以使用的变量名,上面的意思就是说-i的参数存储在dest变量里。
nargs=”+“,表示参数的个数,一个选项可以有一个参数,也可以有多个参数,”+“表示至少有一个参数,如果没有,解析的时候就会出错的。
help=”…”是对这个选项的说明,当使用-h选项时,这个参数的内容就会被输出的。
4)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 and complex;
dest=:表示此option在经过optionparser解析后的options对象中成员的名字,默认使用long option string;
default=:表示比option的默认值;
metavar=:表示显示到help中option的默认值;
const=:当action为store_const的时候,需要设置此值;
choices=:当设置type为choices时,需要设置此值;