python 参数定义库argparse

python 参数定义库argparse

 

 

这一块的官方文档在这里

注意到这个库是因为argparse在IDE中和在ipython notebook中使用是有差异的,习惯了再IDE里面用,转到ipython中会报错,究其原因,还是对库的本质不够理解。

打开argparse.py,里面有很多class,但是,实际笨妞貌似只用过ArgumentParser。ArgumentParser是用来创建argparse类的。

一般的应用过程是这样的:

import argparse

parser = argparse.ArgumentParser(description='Process some integers.')
parser.add_argument('integers', metavar='N', type=int, nargs='+', 
                    help='an integer for the accumulator')
parser.add_argument('--sum', dest='accumulate', action='store_const',
                    const=sum, default=max,
                    help='sum the integers (default: find the max)')

args = parser.parse_args()
print(args.accumulate(args.integers))

包含了创建参数类,添加参数,存储和使用参数。

执行如下命令:

python xx.py 1 2 3 4

结果:

4

 

ArgumentParser可配置的参数很多,如下图,但大多都没必要配置的。

 

add_argument添加参数,这个方法配置参数来告诉系统命令行如何传输参数进来。可配置的参数如下:

* name or flags - 名称或选项字符串列表, e.g. foo or -f, --foo.
* action - 参数如果定义了选项,表示这是一个操作参数,至于调用时做哪种操作由用户输入或者default决定。
* nargs - 应该使用的命令行参数数。.
* const - 某些动作或参数个数的常数值。.
* default - 如果命令行没有对输入这个参数相应的值,则此参数用default给出的值.
* type -将用户输入的值转化为哪种类型.
* choices - 参数可输入值的范围或选择.
* required - 命令行输入的值是否可以被忽略(布尔量).
* help - 参数的简要描述.
* metavar - useage中显示的参数的名称.
* dest - 要添加到解析参数返回的对象中的属性的名称.

 

parser_args将解析参数传递到一个空间中,后续可以通过变量访问。

* args - 要解析的字符串序列,默认值取自sys.argv。List of strings to parse. The default is taken from sys.argv.
* namespace -一个接受属性的对象。默认是一个新的空命名空间对象。

 

通过IDE和ipython使用argparser的差异就在“args = parser.parse_args()”。IDE中parse_args()可以直接使用,只要在命令行执行时,要求必须设置的参数给都值了就没有问题,如果所有参数都有默认值,py文件执行时,不给参数也不会出错。而ipython 在parse_args()这句必须配置args,即便add_argument添加的参数都有默认值也要在配置args,不然执行会报如下错误:

ipykernel_launcher.py: error: unrecognized arguments: -f C:\Users\Administrator\AppData\Roaming\jupyter\runtime\kernel-eeea08d1-8918-441d-9352-59cae31c447e.json
An exception has occurred, use %tb to see the full traceback.

SystemExit: 2

对于含有必须输入值的函数,这个问题是合理的,因为ipython里面读参数不通过命令行,必须通过parse_args传值。

但是,如下程序

import argparse
parser = argparse.ArgumentParser(description='Process some integers.')
parser.add_argument('--a_para', default=2, type=int, required=False,
                    help='first parameter')
parser.add_argument('--b_para',  default=3,type=int, required=False,
                    help='second parameter')
args = parser.parse_args()
print(args.a_para, args.b_para)

 

直接在IDE中运行,不通过命令行,不传参数便可以成功.

2 3

 

但在ipython中必须是这样的

import argparse

parser = argparse.ArgumentParser(description='Process some integers.')
parser.add_argument('--a_para', default=2, type=int, required=False,
                    help='first parameter')
parser.add_argument('--b_para',  default=3,type=int, required=False,
                    help='second parameter')

args = parser.parse_args(['--a_para', '2'])  #至少输入一个参数
print(args.a_para, args.b_para)

输出:

2 3

是不是很无厘头,然而就是这样的。

 

posted @   菜鸡一枚  阅读(1451)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
历史上的今天:
2015-06-29 既然三角形是世界上最稳固的结构,为什么建筑不都做成金字塔的样子呢?
2015-06-29 时间管理入门攻略:番茄工作法从熟悉到依赖
2015-06-29 中国学者学术报告之不好习惯
2015-06-29 8款肉菜的做法集锦
2015-06-29 用人单位重视本科学历与高校争抢生源
2015-06-29 深度学习“引擎”之争:GPU加速还是专属神经网络芯片?
2015-06-29 Regularized Linear Regression with scikit-learn
点击右上角即可分享
微信分享提示