Python命令行解析工具argparse模块

 更新时间:2023年05月18日 09:46:27   作者:FLy_鹏程万里  
这篇文章主要介绍了Python命令行解析工具argparse模块,argparse模块是一个python标准库,它主要用于对用户从客户端输入的命令进行解析,这使得编写用户友好的命令行接口变得非常容易,需要的朋友可以参考下

argparse模块简介

argparse模块是一个python标准库,它主要用于对用户从客户端输入的命令进行解析,这使得编写用户友好的命令行接口变得非常容易。

程序只需要定义好用户可以从终端可以输入哪些参数,以及参数对应的含义、数据类型即可,然后argparse将负责从sys.argv中解析出这些参数。argparse模块还会自动生成帮助信息和使用信息并且当用户赋给程序非法的参数的时候会出现友好的错误提示信息。

使用方法

(1)导入argparse模块

(2)创建一个解析器对象

(3)使用对象内置的add_argument()方法添加需要关注的命令参数和选项

(4)之后调用parse_args()方法解析命令即可

示例:

import argparse                     #导入argparse该模块;
parser = argparse.ArgumentParser()  #创建一个解析器对象
parser.add_argument()               #添加令行参数和选项,每一个add_argument方法对应一个参数或选项;
args=parser.parse_args()            #调用parse_args()方法进行解析,解析成功之后即可使用    

ArgumentParser对象介绍

class argparse.ArgumentParser(
                prog=None, 
                usage=None, 
                description=None, 
                epilog=None, 
                parents=[], 
                formatter_class=argparse.
                HelpFormatter, 
                prefix_chars='-',
                fromfile_prefix_chars=None, 
                argument_default=None, 
                conflict_handler='error', 
                add_help=True)

参数说明:

参数描述
prog程序的名字(默认:sys.argv[0])
usage描述程序用法的字符串(默认:从解析器的参数生成)
description参数帮助信息之前的文本(默认:空)
epilog参数帮助信息之后的文本(默认:空)
parentsArgumentParser 对象的一个列表,这些对象的参数应该包括进去
formatter_class定制化帮助信息的类
prefix_chars可选参数的前缀字符集(默认:‘-‘)
fromfile_prefix_chars额外的参数应该读取的文件的前缀字符集(默
argument_default参数的全局默认值(默认:None)
conflict_handler解决冲突的可选参数的策略(通常没有必要)
add_help给解析器添加-h/–help 选项(默认:True)

add_argument函数简介

ArgumentParser.add_argument(
            name or flags...
            [, action]
            [, nargs]
            [, const]
            [, default]
            [, type]
            [, choices]
            [, required]
            [, help]
            [, metavar]
            [, dest])

参数说明

参数描述
name or flags选项字符串的名字或者列表,例如foo 或者-f, –foo
action在命令行遇到该参数时采取的基本动作类型。
nargs应该读取的命令行参数数目。
const某些action和nargs选项要求的常数值。
default如果命令行中没有出现该参数时的默认值。
type命令行参数应该被转换成的类型。
choices参数可允许的值的一个容器。
required - 该命令行选项是否可以省略(只针对可选参数)。
help参数的简短描述。
metavar参数在帮助信息中的名字。
dest给parse_args()返回的对象要添加的属性名称。

其中“type”、“help”、“action”、“default”、“name ”、“dest”使用最为频繁

实战演示

(1)可选参数

代码如下:

import argparse
parser=argparse.ArgumentParser()
parser.add_argument("-display",help="display the message!")
args=parser.parse_args()
if args.display:
    print "Display is trun on!"

运行结果:

注:可选参数可以在add_argment("这里如果加上“-”,则说明是可选的,否则是必须的")定义

(2)短选项

有时候写一个匹配项的时候还需要写全拼,实在是有些麻烦,在Linux中大多数的交互命令都有简写,那么我们也可以来进行设置短选项

代码如下:

import argparse
parser=argparse.ArgumentParser()
parser.add_argument("-d","--display",help="display the message!",action="store_true")
args=parser.parse_args()
if args.display:
    print "Display is trun on!"

(3)结合位置参数与可选参数

代码如下:

import argparse  
parser = argparse.ArgumentParser()  
parser.add_argument("square", type=int,  
                    help="display a square of a given number")  
parser.add_argument("-v", "--verbose", action="store_true",  
                    help="increase output verbosity")  
args = parser.parse_args()  
answer = args.square**2  
if args.verbose:  
    print "the square of {} equals {}".format(args.square, answer)  
else:  
    print answer  

运行结果如下:

到此这篇关于Python命令行解析工具argparse模块的文章就介绍到这了,更多相关Python的argparse模块内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python成功解决读文件出现:IOError: [Errno 0] Error的错误

    Python成功解决读文件出现:IOError: [Errno 0] Error的错误

    在Python编程中,处理文件是常见的任务之一,但偶尔也会遇到各种错误,包括IOError,尽管Python 3.x中IOError已被OSError和FileNotFoundError等更具体的异常所取代,由于[Errno 0]不直接指向具体的错误类型,我们将讨论一系列可能导致IOError的常见情况,需要的朋友可以参考下
    2024-07-07
  • python numpy.ndarray中如何将数据转为int型

    python numpy.ndarray中如何将数据转为int型

    这篇文章主要介绍了python numpy.ndarray中如何将数据转为int型,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • python机器学习实战之树回归详解

    python机器学习实战之树回归详解

    这篇文章主要为大家详细介绍了python机器学习实战之树回归的相关代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-12-12
  • Jupyter Notebook远程登录及密码设置操作

    Jupyter Notebook远程登录及密码设置操作

    今天小编就为大家分享一篇Jupyter Notebook远程登录及密码设置操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-04-04
  • python的多元数据类型(上)

    python的多元数据类型(上)

    这篇文章主要为大家详细介绍了python的多元数据类型,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • python抓取网页时字符集转换问题处理方案分享

    python抓取网页时字符集转换问题处理方案分享

    python学习过程中发现英文不好学起来挺困难的,其中小弟就遇到一个十分蛋疼的问题,百度了半天就没找到解决办法~囧~摸索了半天自己解决了,记录下来与君共勉。
    2014-06-06
  • 利用Python模拟谷歌的小恐龙游戏

    利用Python模拟谷歌的小恐龙游戏

    谷歌流量器中有个很有名的彩蛋:当你网络出现问题时,就会出现一个“小恐龙游戏”。本文就主要为大家介绍了如何用Python模拟实现这一小游戏,感兴趣的同学可以学习一下
    2021-12-12
  • 对Keras自带Loss Function的深入研究

    对Keras自带Loss Function的深入研究

    这篇文章主要介绍了对Keras自带Loss Function的深入研究,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-05-05
  • Python元组常见操作示例

    Python元组常见操作示例

    这篇文章主要介绍了Python元组常见操作,结合实例形式分析了Python元组的概念、功能、常见定义、获取、遍历等相关操作技巧与注意事项,需要的朋友可以参考下
    2019-02-02
  • python装饰器常见使用方法分析

    python装饰器常见使用方法分析

    这篇文章主要介绍了python装饰器常见使用方法,结合实例形式分析了Python装饰器的功能及三种常见的装饰模式使用技巧,需要的朋友可以参考下
    2019-06-06

最新评论