argparse包的一个作用是我们可以通过命令行来更改程序中的参数,就是说可以在不修改程序的情况下更改一些需要调整的参数。下面举一个例子。

实例

假设我们写了一个求圆柱体体积的程序:

import mathdef cylinder_volume(redius, height):vol = math.pi * (redius**2) * heightreturn volif __name__ == '__main__':print(cylinder_volume(2, 4))

程序文件命名为parse_demo.py,用命令行运行这个程序:

我们计算得到半径为2、高为4的圆柱体体积,但如果我们想计算半径为3、高为5圆柱体的体积,我们不得不回到程序中去修改参数。但如果使用了argparse包,我们可以直接在命令行界面修改参数。程序如下(程序中的一些函数参数我们将在后文介绍)。

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import math
import argparseparser = argparse.ArgumentParser(description='Calculate a volume of a cylinder')   # 创建一个解析对象
parser.add_argument('radius', type=int, help='Radius of Cylinder')   # 向该对象中添加你要关注的命令行参数和选项
parser.add_argument('height', type=int, help='Height of Cylinder')
args = parser.parse_args()   # 对变量进行解析,从指定的选项中返回一些数据。变量与相应的数据组成字典的items,存到args字典中def cylinder_volume(redius, height):vol = math.pi * (redius**2) * heightreturn volif __name__ == '__main__':print(cylinder_volume(args.radius, args.height))

用命令行运行这个程序:

我们在python argparse_demo.py后面加了两个数字,第一个数字会被传给radius参数,第二个数字会被传给height参数,因为我们默认使用的是位置参数。通过修改最后两个数字,我们可以很轻松的修改radius和height,计算得到相应的圆柱体体积。

argparse.ArgumentParser()方法参数,一般我们只选择用description

  1. description - 命令行帮助的开始文字,大部分情况下,我们只会用到这个参数
  2. epilog - 命令行帮助的结尾文字
  3. prog - (default: sys.argv[0])程序的名字,一般不需要修改,另外,如果你需要在help中使用到程序的名字,可以使用%(prog)s
  4. prefix_chars - 命令的前缀,默认是-,例如-f/–file。有些程序可能希望支持/f这样的选项,可以使用prefix_chars=”/”
  5. fromfile_prefix_chars - (default: None)如果你希望命令行参数可以从文件中读取,就可能用到。例如,如果fromfile_prefix_chars=’@’,命令行参数中有一个为”@args.txt”,args.txt的内容会作为命令行参数
  6. add_help - 是否增加-h/-help选项 (default: True),一般help信息都是必须的,所以不用设置。
  7. parents - 类型是list,如果这个parser的一些选项跟其他某些parser的选项一样,可以用parents来实现继承,例如parents=[parent_parser]
  8. 三个允许的值:
# class argparse.RawDescriptionHelpFormatter 直接输出description和epilog的原始形式(不进行自动换行和消除空白的操作)
# class argparse.RawTextHelpFormatter 直接输出description和epilog以及add_argument中的help字符串的原始形式(不进行自动换行和消除空白的操作)
# class argparse.ArgumentDefaultsHelpFormatter 在每个选项的帮助信息后面输出他们对应的缺省值,如果有设置的话。这个最常用吧!
  1. argument_default - (default: None)设置一个全局的选项的缺省值,一般每个选项单独设置,所以这个参数用得少,不细说
  2. usage - (default: generated)如果你需要修改usage的信息(usage: PROG [-h] [–foo [FOO]] bar [bar …]),那么可以修改这个,一般不要修改。
  3. conflict_handler - 不建议使用。这个在极端情况下才会用到,主要是定义两个add_argument中添加的选项的名字发生冲突时怎么处理,默认处理是抛出异常。

add_argument()方法参数

  1. name or flags - 指定参数的形式,想写几个写几个,不过我们一般就写两个,一个短参数,一个长参数,例如”–r”, “–radius”
  2. 可选的选项,位置不固定,想怎么写就怎么写,默认是可选的 # parser.add_argument(“-f”, “–file”, help=”test test test”)
  3. 位置固定的选项,例如”prog i_am_bar”,这样子的话,i_am_bar就是bar选项的值啦,默认是必须有的 # parser.add_argument(“bar”, help=”test test test”)
  4. nargs - 指定这个参数后面的value有多少个,例如,我们希望使用-n 1 2 3 4,来设置n的值为[1, 2, 3, 4] #parser.add_argument(“-n”, “–num”, nargs=”+”, type=int) # 这里nargs=”+”表示,如果你指定了-n选项,那么-n后面至少要跟一个参数,+表示至少一个,?表示一个或0个,0个或多个 。
  5. default - 如果命令行没有出现这个选项,那么使用default指定的默认值 #parser.add_argument(“+g”, “++gold”, help=”test test test”,default=”test_gold”)#需要prefix_chars包含”+” 。
  6. type - 如果希望传进来的参数是指定的类型(例如 float, int or file等可以从字符串转化过来的类型),可以使用 #parser.add_argument(“-x”, type=int) 。
  7. choices - 设置参数值的范围,如果choices中的类型不是字符串,记得指定type哦 #parser.add_argument(“-y”, choices=[‘a’, ‘b’, ‘d’])
  8. required - 如果required=True那么参数就是必须提供的了。默认为False.
  9. metavar - 参数的名字,在显示帮助信息时才用到. # parser.add_argument(“-o”, metavar=”OOOOOO”)
  10. help - 设置这个选项的帮助信息
  11. dest - 设置这个选项的值就是解析出来后放到哪个属性中 #parser.add_argument(“-q”, dest=”world”)
  12. args = parser.parse_args(args) # 如果你没有args参数,那么就使用sys.argv,也就是命令行参数啦。有这个参数,就方便我们调试啊 。# args.world就是-q的值啦
  13. action - The basic type of action to be taken when this argument is encountered at the command line.
  14. const - A constant value required by some action and nargs selections.

add_argument()中使用flags参数

对于上面实例中用到的带argparse包的程序, 我们复制如下:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import math
import argparseparser = argparse.ArgumentParser(description='Calculate a volume of a cylinder')
parser.add_argument('radius', type=int, help='Radius of Cylinder')
parser.add_argument('height', type=int, help='Height of Cylinder')
args = parser.parse_args()  def cylinder_volume(redius, height):vol = math.pi * (redius**2) * heightreturn volif __name__ == '__main__':print(cylinder_volume(args.radius, args.height))

命令行运行:

可以看到出来-h之外,其他的参数都是位置参数。

下面我们对程序的第5,6行以及最后一行进行修改:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import math
import argparseparser = argparse.ArgumentParser(description='Calculate a volume of a cylinder')
parser.add_argument('--r', '--radius', type=int, help='Radius of Cylinder')
parser.add_argument('--H', '--height', type=int, help='Height of Cylinder')   # 不要用--h,因为--h已经被占用了
args = parser.parse_args()def cylinder_volume(redius, height):vol = math.pi * (redius**2) * heightreturn volif __name__ == '__main__':print(cylinder_volume(args.r, args.H))

命令行运行:

可以看到,参数都变为optional参数了。

命令行运行:

这时–H和–r的位置可以随意安排了。

互斥参数:mutually exclusive arguments

我们可以在程序中创建一个互斥组,argparse 将会确保互斥组中只有一个参数在命令行中可用。

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import math
import argparseparser = argparse.ArgumentParser(description='Calculate a volume of a cylinder')
parser.add_argument('--r', '--radius', type=int, help='Radius of Cylinder')
parser.add_argument('--H', '--height', type=int, help='Height of Cylinder')
group = parser.add_mutually_exclusive_group()   # 创建一个互斥组,argparse 将会确保互斥组中只有一个参数在命令行中可用
group.add_argument('--q', '--quiet', action='store_true', help='print quiet')   # action='store_true'意味着当我们在命令行给了该参数时,# 该参数但是为True,没给该参数时,它为False
group.add_argument('--v', '--verbose', action='store_true', help='print verbose')
args = parser.parse_args()def cylinder_volume(redius, height):vol = math.pi * (redius**2) * heightreturn volif __name__ == '__main__':volume = cylinder_volume(args.r, args.H)if args.q:print(volume)elif args.v:print('Volume of a Cylinder with radius {} and height {} is {:.3f}'.format(args.r, args.H, volume))else:print('Volume of Cylinder {}'.format(volume))

程序中,我们创建了一个互斥参数组,包含’–q’和’–v’,我们只需给其中一个,也可以一个都不给:

需注意的是,add_mutually_exclusive_group()方法也接受一个 required 参数,表示在互斥组中至少有一个参数是需要的,但互斥参数组目前不支持持 add_argument_group() 的 title 和 description 参数。

python argparse理解与实例相关推荐

  1. python argparse模块用法实例详解

    转载自https://zhuanlan.zhihu.com/p/56922793 argsparse是python的命令行解析的标准模块,内置于python,不需要安装.这个库可以让我们直接在命令行中 ...

  2. python argparse模块_Python argparse模块应用实例解析

    这篇文章主要介绍了Python argparse模块应用实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 简介 argparse是python ...

  3. __init__在python中的用法知乎_python中对_init_的理解及实例解析 python为什么要有一个init函数 知乎...

    Python中"__init__"的意义是什么? Python中__init__的意义依偎着你心跳声如此频繁,就算世界末日小编也会嚣张的笑. 测试人员学python时,应该如何理解 ...

  4. python简单编程例子-中文方便就用中文编程!Python图形界面开发实例

    原标题:中文方便就用中文编程!Python图形界面开发实例 之前做的一个Python小程序,功能很简单,面对用户群也很窄,是五笔编码编.校人员使用的五笔编码编辑器. 这样的"周末" ...

  5. python编程入门经典实例-总算明了python编程入门经典实例

    跟Java语言一样,python语言也有类的概念,直接使用class关键字定义python类.在python类,定义类的方法.然后直接使用类的初始化调用自身,获取相应的属性.以下是小编为你整理的pyt ...

  6. python self理解_Python面向对象总结,让你快速掌握面向对象常用的用法

    python等面向对象的提出是为了更好的处理和管理同属一个类别的事情,这样就可以省去多余重复的基础代码,让程序变得更加简洁和强大.对于学习编程的朋友来说,熟悉掌握面向对象是非常重要的. 下面开始讲讲关 ...

  7. 《 Python List列表全实例详解系列(四)》__列表删除元素(4种方法)删除重复元素(去重)(8种方法)

    <  Python List列表全实例详解系列(四)> __列表删除元素(4种方法)删除重复元素(去重)(8种方法) 我的技术成长&学习资料整理分享之路 我遇到问题查找资料时,经常 ...

  8. Python基础编程入门实例:恺撒密码

    文章目录 Python基础编程入门实例:恺撒密码 一.什么是恺撒密码 二.程序运行环境 三.恺撒密码:加密 3.1.恺撒密码加密实例程序 3.2.恺撒密码加密实例程序运行结果 四.恺撒密码:解密 4. ...

  9. python打开文件的语法_python27语法Python文件打开方式实例详解【a、a+、r+、w+区别】...

    本文实例讲述了Python文件打开方式.分享给大家供大家参考,具体如下: 第一步 排除文件打开方式错误: r只读,r+读写,不创建 w新建只写,w+新建读写,二者都会将文件内容清零 (以w方式打开,不 ...

最新文章

  1. 【视频点播最佳实践】视频点播播放异常排查
  2. MVC 中的Model对象
  3. TestLink学习七:TestLink测试用例Excel转换XML工具
  4. AMD Cpu 性能分析
  5. Linux信号 二 信号处理函数注册
  6. Windows 7/Vista 桌面上为何有两个隐含的 Desktop.INI
  7. vs2017怎么安装python包,vs2017安装pygame,vs2017安装python第三方包
  8. [leedcode][JAVA][365][BFS]
  9. JEECG第17期架构培训班15号开班啦!每期十个名额,想报名的抓紧时间啦!
  10. 实战 | 离线搭建CDH6.20平台 踩坑实录
  11. 约束布局管理器 CAConstraintLayoutManager 以及其不起作用
  12. mysql索引和redis比较_聊聊Mysql索引和redis跳表
  13. 手机在线编程软件Anycodes
  14. 计算机中丢失xvidcore.dll,出现xvidcore.dll not found 问题的解决方法
  15. PLG日志平台搭建: Promtail + Loki + Grafana 全步骤
  16. 用python写一段计算autocad多段线长度的代码
  17. 九. MySQL InnoDB 底层结构
  18. 小米路由器3G R3G 刷入Breed和OpenWrt 20.02.2 的记录
  19. 如何使用 ChatGPT/open ai 接口 进行图片生成(绘画、图片创作)
  20. iOS 偏好设置 NSUserDefault

热门文章

  1. 算法导论——贪心算法:哈夫曼编码(霍夫曼编码)
  2. VirtualBox中修改Ubuntu-server分辨率
  3. 四十一、Android Notification通知详解
  4. 终于要考网络架构师了
  5. linux安装anaconda3提前so,Linux安装anaconda3
  6. 超级直播sop直播源.zip_双11首场虚拟直播,天猫超级直播开创直播新玩法
  7. 广州自由自在进口食品休闲消费的趋势
  8. 一步快速将Smartform output转成生成PDF文件
  9. 平底方向盘比圆形方向盘好在哪?
  10. SAP的号码范围(number range)SNRO和SNUM自动编号工具的用法