argparse 模块详解

1 argparse 模块简介

  argparse是一个用来解析命令行参数的 Python 库,它是 Python 标准库的一部分。argparse 模块使编写用户友好的命令行界面变得容易。程序定义了所需的参数,而 argparse 将找出如何从 sys.argv (命令行)中解析这些参数。argparse 模块还会自动生成帮助和使用消息,并在用户为程序提供无效参数时发出错误。

  使用argparse的主要步骤:

  • 导入argparse包;
  • 创建ArgumentParser()参数对象;
  • 调用add_argument()方法往参数对象中添加参数;
  • 使用parse_args()解析添加参数的参数对象,获得解析对象;程序的其他部分需要使用命令行参数时,用解析对象.参数获取。
import math
import argparse  # 1、导入argpase包


def parse_args():
    parse = argparse.ArgumentParser(description='Calculate cylinder volume')  # 2、创建参数对象
    parse.add_argument('radius', type=int, help='Radius of Cylinder')  # 3、往参数对象添加参数
    parse.add_argument('height', type=int, help='height of Cylinder')
    args = parse.parse_args()  # 4、解析参数对象获得解析对象
    return args

# 计算圆柱体积
def cal_vol(radius, height):
    vol = math.pi * pow(radius, 2) * height
    return vol


if __name__ == '__main__':
    args = parse_args()
    print(cal_vol(args.radius, args.height))  # 5、使用解析对象.参数获取使用命令行参数

  • 命令行参数输入默认按顺序赋值,顺序不同会造成结果不同;
  • 默认命令-h可以获取添加参数时设置的帮助信息;

2 argparse 模块主要参数

2.1 可选参数

parse.add_argument('--radius', default=2, type=int, help='Radius of Cylinder')

通过在参数名前加--,设置为可选参数。如果未输入,则使用default默认值(若未设置default,则会默认赋值None)。

2.2 可选参数引用名

parse.add_argument('-r', '--radius', default=2, type=int, help='Radius of Cylinder')

通过将可选参数设置引用名,可以缩短参数名-r,简化命令行参数输入。

2.3 清除帮助中的参数名信息

parse.add_argument('-r', '--radius', default=2, type=int, metavar='', help='Radius of Cylinder')

metavar在通过-h显示usage 明中的参数名称,对于必选参数默认就是参数名称,对于可选参数默认是全大写的参数名称。这里通过设置为空一律不显示。

2.4 必选参数设置

parse.add_argument('-r', '--radius', default=2, type=int, metavar='', required=True, help='Radius of Cylinder')

当通过设置required=True后,无论参数是否是可选参数,都必须输入。

2.5 列表参数(多参数)传入设置

def parse_args():
    parse = argparse.ArgumentParser(description='Calculate cylinder volume')
    parse.add_argument('-n', '--num', type=int, nargs='+', metavar='', required=True, help='a string of nums')
    args = parse.parse_args()
    return args

2.6 互斥参数使用

# 1、在参数对象中添加互斥组
group = parse.add_mutually_exclusive_group()  
# 2、在互斥组中添加参数(store_true默认当命令行未输入参数则为False,否则为True)
group.add_argument('-b', '--brief', action='store_true', help='print brief message')  
group.add_argument('-v', '--verbose', action='store_true', help='print verbose message')

命令行中bv只能输入二者中的一个参数。

2.7 默认参数设置

parse.set_defaults(height=4)

set_defaults()可以设置一些参数的默认值。

【参考】

  1. 【python 学习杂记】argparse模块使用教程;
  2. Python–argparse 模块
  • 18
    点赞
  • 103
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值