在shell脚本中,若脚本带参数,则在脚本中使用$1、$2...等引用,

在python中,也可以定义类似的引用参数,可以为必选项也可以可选项。

基本用法如下三种:

1、必选项(位置参数)

import argparse

p = argparse.ArgumentParser()
p.add_argument('var',help='Required parameters')
args = p.parse_args()
if args.var:
print(args.var)

若把此代码保存为arg.py,则执行的时候必须带一个参数,否则报错:

python arg.py hello,world

可以使用如下命令查看:

D:\MyTestProject\MyLearn>python ArgParseLearn.py -h
usage: ArgParseLearn.py [-h] var positional arguments:
var Required parameters optional arguments:
-h, --help show this help message and exit

也可以把可选项设置为必选项,在add_argument中设置required为True就可以了,如下设置:

p.add_argument('-p',help='Optional parameters',required = True)

2、可选项一

import argparse

p = argparse.ArgumentParser()
p.add_argument('-p',help='Optional parameters')
args = p.parse_args()
if args.p:
print(args.p)
else:
print('no var')

若把此代码保存为arg.py,则执行的时候可带参数也可不带:

python arg.py

python arg.py hello,world

3、可选项二

import argparse

p = argparse.ArgumentParser()
p.add_argument('--parameter',help='Optional parameters')
args = p.parse_args()
if args.parameter:
print(args.parameter)
else:
print('no parameter')

若把此代码保存为arg.py,则执行的时候可带参数也可不带:

python arg.py

python arg.py hello,world

以上为3种入参方法,其实add_argument有很多参数可供选择:

name - 选项字符串的名字或者列表,例如var、-p等,可以使用-h查看到。

一般来说,单字母用-,多字母使用--,如果-p,-v,--version,--pass等,如果不使用-或者--,默认这个参数必须填写,类似加了required = True

action - 基本动作类型,当前默认有如下一些类型:

store  --这是默认类型,即存储值

store_const  ---保存const参数的值,此时执行文件只带参数,不带变量,如下:

import argparse

p = argparse.ArgumentParser()
p.add_argument('-p',help='Optional parameters',action = 'store_const',const = '')
args = p.parse_args()
print(args.p)

如上代码保存为arg.py,应该这么执行:python arg.py -p

此时打印出来的值为const的值78

store_true和store_false  ---对应布尔值,True和False

append   ---此选项把参数对应的值使用list集合起来,如下:

import argparse

p = argparse.ArgumentParser()
p.add_argument('-p',help='Optional parameters',action = 'append')
args = p.parse_args()
print(args.p)

保存为arg.py,则可以如下执行:python arg.py -p 1 -p 2 -p 89

执行结果为['1', '2', '89']

append_const  ---这个必须有参数const,把const集合起来

count  ----查看参数出现几次

help  ---默认会自动存在的

version  ---必须配合version参数,用法如下:

import argparse

p = argparse.ArgumentParser()
p.add_argument('-v',help='Optional parameters',action = 'version',version = '1.15.1')
args = p.parse_args()
print(args.p)

保存为arg.py,执行python arg.py -v则显示version参数的值

nargs - 对应参数应该获取的变量个数,大于1个变量用list来表示。一般取值有如下几个:

N  数值int型,即nargs=3,nargs=10等

?  表示0个或者1个参数,如nargs = '?'

*  表示0个或者多个参数,如nargs = '*'
+  表示1个或者多个参数,如nargs = '+'

const - 某些action和nargs选项要求的常数值。如果有这个参数,则使用脚本时不需要追加变量

default - 如果命令行中没有出现该参数时该参数的默认值。

type - 命令行参数应该被转换成的类型。支持以下类型:

str,int,float,complex,file。如果没有此参数,默认为str类型

choices - 参数可允许的值的一个容器(列表)。

required - 该命令行选项是否可以省略(只针对可选参数)。

help - 参数的简短描述。

metavar - 参数在帮助信息中的名字,即类似起一个别名。如下:

import argparse

p = argparse.ArgumentParser()
p.add_argument('p',help='Optional parameters',metavar = 'TP')
p.add_argument('--gogo',help='Optional parameters',nargs = 2,metavar = ('new','old'))
args = p.parse_args() print(args.p)

保存为arg.py后执行python arg.py -h,可以看到名称不是p,而是TP:

D:\PycharmProjects\untitled\MyTestProject\MyLearn>python arg.py -h
usage: temp.py [-h] TP positional arguments:
TP Optional parameters optional arguments:
-h, --help show this help message and exit
 --gogo new old  Optional parameters

dest - 给parse_args()返回的对象要添加的属性名称。即给namespace里面的参数起个别名,作用同metavar(只有非位置参数才可以用dest),如下:

import argparse

p = argparse.ArgumentParser()
p.add_argument('-p',help='Optional parameters',metavar = 'TP',dest = 'paaa')
args = p.parse_args()
print(args)

保存为arg.py,然后执行python arg.py -h查看如下:

D:\PycharmProjects\untitled\MyTestProject\MyLearn>python arg.py -h
usage: temp.py [-h] [-p TP] optional arguments:
-h, --help show this help message and exit
-p TP Optional parameters

执行python arg.py -p yy,结果如下:

D:\PycharmProjects\untitled\MyTestProject\MyLearn>python temp.py -p 5
Namespace(paaa='')

对于ArgumentParser类中也有许多参数,查看__ini__如下:

    def __init__(self,
prog=None,
usage=None,
description=None,
epilog=None,
parents=[],
formatter_class=HelpFormatter,
prefix_chars='-',
fromfile_prefix_chars=None,
argument_default=None,
conflict_handler='error',
add_help=True,
allow_abbrev=True):

prog ---程序名称,默认为sys.argv[0]

usage ---程序使用方法介绍,放在帮助的最前面

description ---描述信息,在usage之后,参数之前

epilog ---帮助信息中参数之后的文本信息

parents ---ArgumentParser 对象的一个列表,如果在列表中,会把parents包含的对象的所有参数带过来,如下示例:

import argparse

#父参数
p_parser = argparse.ArgumentParser(add_help=False)
p_parser.add_argument('-f')
#子参数并使用父参数
son = argparse.ArgumentParser(parents = [p_parser])
son.add_argument('-p')
sonargs = son.parse_args()
print(sonargs)

把上述代码保存为arg.py,执行python arg.py -p aa -f body,结果如下:

D:\PycharmProjects\untitled\MyTestProject\MyLearn>python arg.py -p aa -f body
Namespace(f='body', p='aa')

可以看到父参数也可以在这里接收到对应的值

这里要注意的是,若作为父参数,必须要设置add_help = False

formatter_class = HelpFormatter ---格式化的帮助信息,可以自定义

prefix_chars = '-'  ----可选参数的前缀,默认是'-'

fromfile_prefix_chars = None  ---读取额外文件的字符集前缀,如下所示:

import argparse

p = argparse.ArgumentParser(fromfile_prefix_chars = '@')
p.add_argument('-f')
args = p.parse_args()
print(args)
print(args.f)

保存为arg.py,在arg.py同目录下创建一个文件a.txt并输入一行:-f mylife

然后在命令行中执行python arg.py @a.txt,接入如下:

D:\PycharmProjects\untitled\MyTestProject\MyLearn>python arg.py @a.txt
Namespace(f=' mylife')
mylife

argument_default = None ---参数的默认值,默认None

conflict_handler  ---解决参数冲突,如下可以使用新参数顶替就参数:

import argparse

p = argparse.ArgumentParser(conflict_handler = 'resolve')
p.add_argument('-f','--fule',help = 'old')
p.add_argument('--fule',help = 'new')
print(p.parse_args())

保存如上代码为arg.py,执行python arg.py -h,结果如下:

D:\PycharmProjects\untitled\MyTestProject\MyLearn>python arg.py -h
usage: temp.py [-h] [-f FULE] [--fule FULE] optional arguments:
-h, --help show this help message and exit
-f FULE old
--fule FULE new

再执行python arg.py,结果如下:

D:\PycharmProjects\untitled\MyTestProject\MyLearn>python arg.py
Namespace(fule=None)

发现只有一个参数fule,当我们带参数执行时,若带-f则fule参数也可以取得值,若带-f和--fule,此时fule参数值为--fule的参数值。

add_help = True  ---默认增加-h/--help给解释器,若为False则不会自动添加-h/--help选项

allow_abbrev = True ---允许参数简写,默认是允许的,如下:

import argparse

p = argparse.ArgumentParser(allow_abbrev = True)
p.add_argument('--fule',help = 'fule')
p.add_argument('--file',help = 'file')
args = p.parse_args()
print(args)

保存为arg.py,在命令行中执行python arg.py --fu c,执行结果如下:

D:\PycharmProjects\untitled\MyTestProject\MyLearn>python arg.py --fu c
Namespace(file=None, fule='c')

可以看到fule参数获取到了值,如果allow_abbrev = False,则会报错

python之定义参数模块argparse(一)基本使用的更多相关文章

  1. python之定义参数模块argparse(二)高级使用 --传参为函数的实现

    我们在文章python之定义参数模块argparse的基本使用中介绍了argparse模块的基本使用方法 当前传入的参数只能是int.str.float.comlex类型,不能为函数,这有点不方便,但 ...

  2. python命令行解析模块--argparse

    python命令行解析模块--argparse 目录 简介 详解ArgumentParser方法 详解add_argument方法 参考文档: https://www.jianshu.com/p/aa ...

  3. Python 命令行解析模块 —— argparse

    argparse是python标准库里面用来处理命令行参数的库,基本使用步骤如下: 1.import argparse    导入模块 2.parser = argparse.ArgumentPars ...

  4. Python学习笔记(四)Python函数的参数

    Python的函数除了正常使用的必选参数外,还可以使用默认参数.可变参数和关键字参数. 默认参数 基本使用 默认参数就是可以给特定的参数设置一个默认值,调用函数时,有默认值得参数可以不进行赋值,如: ...

  5. python命令行参数解析模块argparse和docopt

    http://blog.csdn.net/pipisorry/article/details/53046471 还有其他两个模块实现这一功能,getopt(等同于C语言中的getopt())和弃用的o ...

  6. python之命令行参数解析模块argparse

    """argparse模块使得写用户友好性命令行接口很容易,程序定义所需要的参数,argparse会从ays.argv中提取出这些参数.argparse模块也能自动的产生 ...

  7. python之参数解析模块argparse

    2.7之后python不再对optparse模块进行扩展,python标准库推荐使用argparse模块对命令行进行解析. 简单入门 先来看个例子: argparse_test.py: import ...

  8. Python 命令行参数解析工具 argparse

    为什么需要argparse 开门见山,举一个简易计算器代码的例子,其中sys.argv用来读取脚本执行时后面传入的参数. def calculator(x, y, operation): if &qu ...

  9. python中关于传递参数模块argprase的一些小坑

    今天在写代码的时候遇到了一个关于parser的一些小坑,记录在此备用. 我们知道在python中可以用argprase来传递一些参数给代码执行,来看下面的例子,假设现在有一个test文件夹,下面有3个 ...

随机推荐

  1. main方法启动spring

    main方式读取spring配置.main方法启动spring/ 有时候只想写一下简单的测试用一下. 新建一个maven项目 依赖pom <?xml version="1.0" ...

  2. java去除查询实体字段多值之间空格

    String str = 需要去除的字段; str.replaceAll(",","");

  3. 把我坑惨的一个update语句

    最近好几次有开发同学在问我,比如下图: 问题归纳起来就是:在MySQL里面update一条记录,语法都正确的,但记录并没有被更新... 刚遇到这个问题的时候,我拿到这条语句直接在测试库里面执行了一把, ...

  4. Windows环境下编译Assimp库生成Android可用的.so或.a文件

    在做项目过程中需要使用Assimp这个3D模型读取库来读取obj格式的模型,因为项目是基于Android平台,采用NDK开发,所以就打算编译Assimp库并生成.so文件.本文使用Assimp-v.5 ...

  5. nginx配置ssl验证

    在上一篇博客中,我们只是通过nginx搭建了反向代理服务,由于需要在小程序中使用https服务,所以需要申请安全证书. 1.在所购买的域名商那申请免费的ssl证书,我买的是阿里的,所以直接在阿里上申请 ...

  6. django用户认证系统——拓展 User 模型

    Django 用户认证系统提供了一个内置的 User 对象,用于记录用户的用户名,密码等个人信息.对于 Django 内置的 User 模型, 仅包含以下一些主要的属性: username,即用户名 ...

  7. VB读写进程的内存

    在窗体部分简单测试了ReadProcessMemory和WriteProcessMemory对另一个程序进程的读写. 由于临时项目变动,又不需要了,所以直接封类,删工程.以下代码没有一个函数经过测试, ...

  8. js函数柯里化,实现bind

    1.柯里化: 把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数而且返回结果的新函数的技术. 举个栗子: 一个计算两数之和的函数,需要传递两个参数,柯里化 ...

  9. SpringBoot几种定时任务的实现方式

    定时任务实现的几种方式: Timer:这是java自带的java.util.Timer类,这个类允许你调度一个java.util.TimerTask任务.使用这种方式可以让你的程序按照某一个频度执行, ...

  10. let和const

    ES6新增了let取代var,let主要有以下特点. 1 只在代码块内有效,代码块外不能使用let声明的变量.let很适合声明循环体的变量. 它可以解决一些闭包的问题存在的问题比如: var a = ...