python常用模块学习:argparse实例教程

2023-02-0113:47:32编程语言入门到精通Comments1,029 views字数 2315阅读模式

argparse 是 Python 内置的一个用于命令项选项与参数解析的模块,通过在程序中定义好我们需要的参数,argparse 将会从 sys.argv 中解析出这些参数,并自动生成帮助和使用信息。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/30674.html

  1. 参数添加步骤
  2. import argparse 首先导入模块
  3. parser = argparse.ArgumentParser()创建一个解析对象
  4. parser.add_argument() 向该对象中添加你要关注的命令行参数和选项
  5. parser.parse_args() 进行解析
  1. argparse.ArgumentParser()参数

须知:一般我们只使用description参数文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/30674.html

参数含义
description命令行帮助的开始文字,大部分情况我们只会使用这个参数
epilog命令行帮助的结尾文字
prog(default: sys.argv[0])程序的名字,一般不需要修改,另外,如果你需要在help中使用到程序的名字,可以使用%(prog)s
prefix_chars命令的前缀,默认是-,例如-f/–file。有些程序可能希望支持/f这样的选项,可以使用prefix_chars=”/”
fromfile_prefix_chars(default: None)如果你希望命令行参数可以从文件中读取,就可能用到。例如,如果fromfile_prefix_chars=’@’,命令行参数中有一个为”@args.txt”,args.txt的内容会作为命令行参数
add_help是否增加-h/-help选项 (default: True),一般help信息都是必须的,所以不用设置
parents类型是list,如果这个parser的一些选项跟其他某些parser的选项一样,可以用parents来实现继承,例如parents=[parent_parser]
argument_default(default: None)设置一个全局的选项的缺省值,一般每个选项单独设置,所以这个参数用得少
usage(default: generated)如果你需要修改usage的信息(usage: PROG [-h] [–foo [FOO]] bar [bar …]),那么可以修改这个,一般不要修改。
conflict_handler不建议使用。这个在极端情况下才会用到,主要是定义两个add_argument中添加的选项的名字发生冲突时怎么处理,默认处理是抛出异常。
class argparse.RawDescriptionHelpFormatter直接输出description和epilog的原始形式(不进行自动换行和消除空白的操作)
class argparse.RawTextHelpFormatter直接输出description和epilog以及add_argument中的help字符串的原始形式(不进行自动换行和消除空白的操作)
class argparse.ArgumentDefaultsHelpFormatter在每个选项的帮助信息后面输出他们对应的缺省值
  1. add_argument()方法参数
参数含义
name or flags指定参数的形式,想写几个写几个,不过我们一般就写两个,一个短参数,一个长参数,看下面的例子”-f”, “–file”
可选的选项位置不固定,想怎么写就怎么写,默认是可选的 # parser.add_argument(“-f”, “–file”, help=”test test test”)
位置固定的选项例如”prog i_am_bar”,这样子的话,i_am_bar就是bar选项的值啦,默认是必须有的 # parser.add_argument(“bar”, help=”test test test”)
nargs指定这个参数后面的value有多少个,例如,我们希望使用-n 1 2 3 4,来设置n的值为[1, 2, 3, 4] #parser.add_argument(“-n”, “–num”, nargs=”+”, type=int) # 这里nargs=”+”表示,如果你指定了-n选项,那么-n后面至少要跟一个参数,+表示至少一个,?表示一个或0个
default如果命令行没有出现这个选项,那么使用default指定的默认值 #parser.add_argument(“+g”, “++gold”, help=”test test test”,default=”test_gold”)#需要prefix_chars包含”+” 。
type如果希望传进来的参数是指定的类型(例如 float, int or file等可以从字符串转化过来的类型),可以使用 #parser.add_argument(“-x”, type=int) 。
choices设置参数值的范围,如果choices中的类型不是字符串,记得指定type哦 #parser.add_argument(“-y”, choices=[‘a’, ‘b’, ‘d’])
required通常-f这样的选项是可选的,但是如果required=True那么就是必须的了 #parser.add_argument(“-z”, choices=[‘a’, ‘b’, ‘d’], required=True)
metavar参数的名字,在显示帮助信息时才用到.
help设置这个选项的帮助信息
dest设置这个选项的值就是解析出来后放到哪个属性中 #parser.add_argument(“-q”, dest=”world”)
args = parser.parse_args(args)如果你没有args参数,那么就使用sys.argv,也就是命令行参数啦。有这个参数,就方便我们调试啊 。# args.world就是-q的值啦
  1. 示例
python常用模块学习:argparse实例教程
python常用模块学习:argparse实例教程
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/30674.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/ymba/30674.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定