Python命令获取用户输入行为模块-argparse

Python命令获取用户输入行为模块-argparse

概述

当我们使用命令运行python脚本的时候,一些非固定参数如果需要我们通过命令输入有以下几种方式:

  1. 使用sys.argv
  2. 使用argparse
  3. 使用fire

本篇文章我们主要介绍argparse的使用

创建解析器

parse = argparse.ArgumentParser(description='我是来接收用户输入的...')

参数说明

def __init__(self,
             prog: str | None = ...,
             usage: str | None = ...,
             description: str | None = ...,
             epilog: str | None = ...,
             parents: Sequence[ArgumentParser] = ...,
             formatter_class: _FormatterClass = ...,
             prefix_chars: str = ...,
             fromfile_prefix_chars: str | None = ...,
             argument_default: Any = ...,
             conflict_handler: str = ...,
             add_help: bool = ...,
             allow_abbrev: bool = ...,
             exit_on_error: bool = ...) -> None
  • prog : 程序的名称(默认:sys.argv[0]) usage - 描述程序用途的字符串(默认值:从添加到解析器的参数生成)
  • description : 在参数帮助文档之前显示的文本(默认值:无)
  • epilog :在参数帮助文档之后显示的文本(默认值:无)
  • parents : 一个 ArgumentParser 对象的列表,它们的参数也应包含在内
  • formatter_class : 用于自定义帮助文档输出格式的类
  • prefix_chars:可选参数的前缀字符集合(默认值:’-’)
  • fromfile_prefix_chars : 当需要从文件中读取其他参数时,用于标识文件名的前缀字符集合(默认值:None)
  • argument_default :参数的全局默认值(默认值: None)
  • conflict_handler :解决冲突选项的策略(通常是不必要的)
  • add_help :为解析器添加一个 -h/–help 选项(默认值: True)
  • allow_abbrev : 如果缩写是无歧义的,则允许缩写长选项 (默认值:True)

添加参数

parse.add_argument('-e', '--env', default='sit', required=False, help='请输出要打包的环境【sit/uat/prod】')
parse.add_argument('-r', '--remark', nargs='+', default='无', required=False, help='请输出要本次更新内容')
 
print(parse.parse_args())

用户输入

python argparse_simple.py -e=sit -r 1.network 2.ui

在这里插入图片描述

参数介绍

def add_argument(self,
                 *name_or_flags: str,
                 action: str | Type[Action] = ...,
                 nargs: int | str = ...,
                 const: Any = ...,
                 default: Any = ...,
                 type: (str) -> _T | (str) -> _T | FileType = ...,
                 choices: Iterable[_T] | None = ...,
                 required: bool = ...,
                 help: str | None = ...,
                 metavar: str | Tuple[str, ...] | None = ...,
                 dest: str | None = ...,
                 version: str = ...,
                 **kwargs: Any) -> Action
  • name or flags:一个命名或者一个选项字符串的列表,例如 env-e, --env

     env 可直接输入命令参数` sit`
    
     -e 需要输入命令名称+命令参数:`-e=sit`
    
    --env  需要输入命令名称+命令参数:`-env=sit`,是`-e`的全拼
    
  • action :当参数在命令行中出现时使用的动作基本类型。

  • nargs : 命令行参数个数

    nargs=2 :表示可接收两个参数,以空格隔开,会输出一个列表(`env sit uat` => `env=[sit,uat]`)
    
    nargs='+' 表示可接收多个参数,以空格隔开
    
  • const :被一些 action 和 nargs 选择所需求的常数。

  • default : 当参数未在命令行中出现时使用的值。

  • type : 命令行参数应当被转换成的类型。

  • choices : 可用的参数的容器。

  • required : 此命令行选项是否是必填

  • help : 一个此选项作用的简单描述。

  • metavar : 在使用方法消息中使用的参数值示例。

  • dest : 被添加到 parse_args() 所返回对象上的属性名。

    其中最常用的可选参数是:defaulttypehelpnargs下面我就在之前的test.py的基础上更改一些参数来说明其使用方法

    完整示例

import argparse


def simple():
    # 创建解析器
    parse = argparse.ArgumentParser(description='我是来接收用户输入的...')

    parse.add_argument('-e', '--env', default='sit', required=False, help='请输出要打包的环境【sit/uat/prod】')
    parse.add_argument('-r', '--remark', nargs='+', default='无', required=False, help='请输出要本次更新内容')

    args = parse.parse_args()
    env = args.env
    remark = " , ".join(str(i) for i in args.remark)
    print(f'env={env},remark={remark}')
    print(parse.parse_args())


if __name__ == '__main__':
    simple()

在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

吴唐人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值