官网文档

https://docs.python.org/3/howto/argparse.html   # 简易教程
https://docs.python.org/3/library/argparse.html#module-argparse # 详细教程

add_argument()方法中的一些参数说明

add_argument('-f', '--foo')  # 可选参数
add_argument('foo') # 位置参数
action #该action关键字参数指定的命令行参数应该如何处理
action = 'store' # 默认操作仅存储参数的值,可以不写
action = 'store_const' # 将存储由const关键字参数指定的值
action = 'store_true' # 这些是'store_const'分别存储值True和False的情况下使用
action = 'store_false'
action = 'append' # 存储一个列表,并将命令行的每个参数值附加到列表中
action = 'append_const' # 存储一个列表,并将const关键字参数指定的值附加到列表中,可用于多个参数需要将常量存储到同一列表,const默认参数为None
action = 'count' # 计算关键字参数出现的次数
action = 'extend' # 存储一个列表,并将每个参数值添加到列表中
nargs : 将单个命令行参数与要执行的单个操作相关联,并收集到一个列表中
nargs = N(一个整数) # nargs=2,命令行python test.py --foo a b 将a,b收集到一个列表中
nargs = ? # 表示从命令行使用一个参数,作为选项参数的值,如果命令行指定了参数的值则使用(python test.py --foo xx),如果不存在命令行参数(python test.py),使用default默认值,如果存在可选项参数(python test.py --foo),但是没有指定参数值,会使用const的值。
nargs = * # 存在的所有命令行参数都收集到一个列表中
nargs = + # 跟*用法一样,都会收集到一个列表中,但是如果没有命令行参数则会报错
default # 指定默认值
type # 指定类型 int float等
choices # 指定某些命令行参数应从一组受限制的值中选择,如果参数不是可接受的值一直,则报错
required=True # 指定参数值为必填
help #帮助信息说明

type指定值的类型

import argparse
parser = argparse.ArgumentParser()
# 用于指定程序愿意接受的命令行选项
# type用于指定类型
# parser.add_argument('square', help='echo the string you use here', type=int)
args = parser.parse_args()
print(args.square**2)
运行:
python test.py 4
结果:16

可选参数--

import argparse
parser = argparse.ArgumentParser()
# --表示可选参数
parser.add_argument('--verbosity', help='increase output verbosity')
args = parser.parse_args()
# 如果加了参数,那么就会执行这段代码
if args.verbosity:
print('verbosity turned on')
运行
python test.py --verbosity # 不会打印if语句中的代码,且会报错
python test.py --verbosity 4 # 加了参数所以会打印if语句中的代码

可参数中action指定store_true默认隐式传递True

import argparse
parser = argparse.ArgumentParser()
# action用来指定值,并将True分配给args.verbose
# 如果在指定程序的时候,你额外加了参数的话,那么就会报错
parser.add_argument('--verbose', help='increase output verbosity', action='store_true')
args = parser.parse_args()
if args.verbose:
print('verbosity turned on')
运行:
python test.py --verbose # 打印if语句中的代码
python test.py --verbose 1 # 则会报错,因为已经指定了默认值,加参数的话会报错

可选选项之简短选项

import argparse
parser = argparse.ArgumentParser()
# 参数一为参数二的简短缩写,执行程序时,直接使用-v,而不使用--verbose了
parser.add_argument('-v', '--verbose', help='increase output verbosity', action='store_true')
args = parser.parse_args()
if args.verbose:
print('verbosity turned on')
运行:
python test.py -v # 打印if语句的代码

结合位置参数和可选参数(可选参数中指定了默认值store_true即表示True)

import argparse
parser = argparse.ArgumentParser()
# 执行代码的时候需要输入参数
parser.add_argument('square', type=int, help='display a square of a given number')
# 执行代码的时候不需要输入参数,因为指定了默认值
parser.add_argument('-v', '--verbose', help='increase output verbosity', action='store_true')
args = parser.parse_args()
# 参数**2
answer = args.square**2
# 如果为真执行下面代码
if args.verbose:
print(f'the square of {args.square} equals {answer}')
# 否则执行下面代码
else:
print(answer)
运行:
python test.py 4 # 16
python test.py -v 4 # 4, 16 顺序无关紧要
python test.py 4 -v # 4, 16

结合位置参数和可选参数(没有指定默认值)

import argparse
parser = argparse.ArgumentParser()
parser.add_argument('square', help='display a square of a given number', type=int)
parser.add_argument('-v', '--verbose', help='increase output verbose', type=int)
args = parser.parse_args()
answer = args.square**2
if args.verbose == 2:
print(f'the square of {args.square} equals {answer}')
elif args.verbose == 1:
print(f'{args.square}^2 == {answer}')
else:
print(answer)
运行:
python test.py 4 # 16 4被square接收了, -v是指定可选参数,没有用-v所以就不会使用,但是要知道不指定-v,则会有隐式的默认值None
python test.py 4 -v # 会报错,因为使用了-v,所以就要加参数
python test.py 4 -v 1 # 4^2 == 16
python test.py 4 -v 2 # the square of 4 equals 16

可选参数中指定choices选项来限制接收的参数

import argparse
parser = argparse.ArgumentParser()
parser.add_argument('square', type=int, help='display a square of a given number')
parser.add_argument('-v', '--verbose', choices=[0, 1, 2], help='increase output verbose', type=int)
args = parser.parse_args()
answer = args.square**2
if args.verbose == 2:
print(f'the square of {args.square} equals {answer}')
elif args.verbose == 1:
print(f'{args.square}^2 == {answer}')
else:
print(answer) 运行:
python test.py 4 -v 0 # 16 , 因为-v的参数为0在choices里面,所以会执行else语句,起码不会报错了
python test.py 4 -v 3 # 会报错,因为-v的参数3,不在choices里面

可选参数中指定action="count"用来计算特定可选参数的出现次数,即把出现的次数当做参数传递

import argparse
parser = argparse.ArgumentParser()
parser.add_argument('square', type=int, help='square number')
parser.add_argument('-v', '--verbose', action='count', help='verbose ok')
args = parser.parse_args()
answer = args.square**2
if args.verbose == 2:
print('the square of {} equals {}'.format(args.square, answer))
elif args.verbose == 1:
print('{}^2 == {}'.format(args.square, answer))
else:
print(answer)
运行:
python test.py 4 -v # 因为上面可选参数中指定了action='count', 所以这里的-v就表示出现了1次,即把1当做参数传递给verbose
python test.py 4 -vv # -vv表示出现了2次,即把2当做参数传递给了verbose
python test.pt 4 --verbose --verbose # 同上面-vv用法一致
python test.py 4 -v 1 # 报错,因为用了action='count',即把出现的次数当做参数传递给verbose,所以再传递参数的话就会报错

可选参数指定default默认值,使程序不使用可选参数时,做比较判断时不会报错

import argparse
parser = argparse.ArgumentParser()
parser.add_argument('square', type=int, help='square number')
parser.add_argument('-v', 'verbose', action='count', default=0, help='verbose ok')
args = parser.parse_args()
answer = args.square**2
if args.verbose >= 2:
print("the square of {} equals {}".format(args.square, answer))
elif args.verbose >= 1:
print("{}^2 == {}".format(args.square, answer))
else:
print(answer) python test.py 4 -vvv # the square of 4 equals 16
python test.py 4 -vvvv # the square of 4 equals 16
python test.py 4 # 16 这边要注意下,因为我们在可选参数中加了default默认值=0,所以不指定-v的时候,它不会报错,不然不加的话默认-v隐式的会有默认值None,None无法用比较符跟数值做比较

add_mutually_exclusive_group()用来解决多个可选参数中的冲突选项,即多个可选参数时,可用长格式选项和简写格式选项结合使用

import argparse
parser = argparse.ArgumentParser()
group = parser.add_mutually_exclusive_group()
group.add_argument('-v', '--verbose', action='store_true')
group.add_argument('-q', '--quit', action='store_true')
parser.add_argument('x', type=int, help='the base')
parser.add_argument('y', type=int, help='the exponent')
args = parser.parse_args()
answer = args.x ** args.y
if args.quit:
print(answer)
elif args.verbose:
print("{} to the power {} equals {}".format(args.x, args.y, answer))
else:
print("{}^{} == {}".format(args.x, args.y, answer))
运行:
python test.py 4 2 -v --quit

description描述信息,可通过python test.py --help查看

import argparse
parser = argparse.ArgumentParser(description="calculate X to the power of Y"))
group = parser.add_mutually_exclusive_group()
group.add_argument('-v', '--verbose', action='store_true')
group.add_argument('-q', '--quit', action='store_true')
parser.add_argument('x', type=int, help='the base')
parser.add_argument('y', type=int, help='the exponent')
args = parser.parse_args()
answer = args.x ** args.y
if args.quit:
print(answer)
elif args.verbose:
print("{} to the power {} equals {}".format(args.x, args.y, answer))
else:
print("{}^{} == {}".format(args.x, args.y, answer))
运行:
python test.py 4 2 -v --quit

python内置模块argparse的使用的更多相关文章

  1. python内置模块collections介绍

    目录 python内置模块collections介绍 1.namedtuple 2.deque 3.defaultdict 4.OrderedDict 5.ChainMap 6.Counter 7.小 ...

  2. python内置模块(4)

    这一部分是python内置模块系列的最后一部分,介绍了一些小巧有用的内置模块. 目录: 1.random 2.shelve 3.getpass 4.zipfile 5.tarfile 6.bisect ...

  3. Python学习笔记【第八篇】:Python内置模块

    什么时模块 Python中的模块其实就是XXX.py 文件 模块分类 Python内置模块(标准库) 自定义模块 第三方模块 使用方法 import 模块名 form 模块名 import 方法名 说 ...

  4. python中argparse模块用法实例详解

    python中argparse模块用法实例详解 这篇文章主要介绍了python中argparse模块用法,以实例形式较为详细的分析了argparse模块解析命令行参数的使用技巧,需要的朋友可以参考下 ...

  5. python中argparse

    python中argparse 在很多编程语言中,运行程序可以直接使用function(a,b,……)运行程序,但是在python中就无法实现,那么我们如何在命令行中传递参数呢?在python的中,有 ...

  6. Python内置模块与标准库

    Python内置模块就是标准库(模块)吗?或者说Python的自带string模块是内置模块吗? 答案是:string不是内置模块,它是标准库.也就是说Python内置模块和标准库并不是同一种东西. ...

  7. python内置模块[re]

    python内置模块[re] re模块: python的re模块(Regular Expression正则表达式)提供各种正则表达式的匹配操作,在文本解析.复杂字符串分析和信息提取时是一个非常有用的工 ...

  8. python内置模块[sys,os,os.path,stat]

    python内置模块[sys,os,os.path,stat] 内置模块是python自带功能,在使用内置模块时,需要遵循 先导入在 使用 一.sys 对象 描述 sys.argv 命令行参数获取,返 ...

  9. Python内置模块和第三方模块

    1.Python内置模块和第三方模块 内置模块: Python中,安装好了Python后,本身就带有的库,就叫做Python的内置的库. 内置模块,也被称为Python的标准库. Python 2.x ...

  10. python内置模块介绍(一)

     本文主要介绍模块列表如下: os sys re time datetime random shutil subprocess os模块 os.getcwd()                    ...

随机推荐

  1. [转帖]关于linux:NUMA架构下的内存延迟区别测试

    https://lequ7.com/guan-yu-linuxnuma-jia-gou-xia-de-nei-cun-yan-chi-qu-bie-ce-shi.html 当初的服务器物理机CPU个别 ...

  2. 华为云DTSE携手“灵康宜”构造一站式智慧健康检测云平台

    本文分享自华为云社区<华为云DTSE携手"灵康宜"构造一站式智慧健康检测云平台>,作者: HuaweiCloudDeveloper. 打破传统健康监测方式桎梏--非接触 ...

  3. 从零开始配置 vim(7)——自动命令

    这篇我们来谈论vim一个相当重要的东西--自动命令. 从编程的角度来看,自动命令有点类似于事件响应,或者回调函数之类.当外部发生某些事件的时候,自动执行事先定义好的一组命令. 定义一个自动命令的格式如 ...

  4. Jmeter报错权限不够

    Jmeter报错权限不够 解决办法: chmod +x jmeter

  5. 设计模式学习-使用go实现中介者模式

    中介模式 定义 优点 缺点 适用范围 代码实现 参考 中介模式 定义 中介模式(Mediator):用一个中介对象来封装一系列的对象交互.中介者使个各对象不需要显示的相互引用,从而使其藕合松散,而且可 ...

  6. 21.9 Python 使用Selenium库

    Selenium是一个自动化测试框架,主要用于Web应用程序的自动化测试.它可以模拟用户在浏览器中的操作,如打开网页.点击链接.填写表单等,并且可以在代码中实现条件判断.异常处理等功能.Seleniu ...

  7. C/C++ 使用CRC检测内存映像完整性

    前面的那一篇文章中所使用的技术只能有效抵抗解密者直接修改硬盘文件,当我们使用动态补丁的时候,那么内存中同样不存在校验效果,也就无法抵御对方动态修改机器码了,为了防止解密者直接对内存打补丁,我们需要在硬 ...

  8. C++ STL 标准模板库(非变易/变易)算法

    C++ STL模板是惠普实验室开发的标准开发模板,STL是C++的一部分,STL可分为容器(containers).迭代器(iterators).空间配置器(allocator).配接器(adapte ...

  9. 基于SpringBoot应⽤的logback⽇志配置

    SpringBoot默认整合了logback-classic⽇志框架,我们需要对logback⽇志框架进⾏配置 以⾃定义⽇志输出格式.⽇志⽂件配置.⽇志⽂件保存策略等信息 <?xml versi ...

  10. 面试官:什么是JIT、逃逸分析、锁消除、栈上分配和标量替换?

    JIT.逃逸分析.锁消除.栈上分配和标量替换等都属于 JVM 的优化手段,JVM 优化手段是指在运行 Java 程序时,通过对字节码的编译和执行过程进行优化,以提升程序的性能和效率. JVM 优化手段 ...