python 命令行参数 argparse详解

简介: 这篇文章是关于Python命令行参数解析库`argparse`的详细解释和使用教程。文中提供了完整的代码模板,包括如何定义命令行参数、如何添加位置参数、可选参数和布尔参数,以及如何解析和使用这些参数。文章还包含了示例代码和测试用例,以展示如何在实际程序中应用`argparse`库。

完整模板

首先,直接给出完整的使用,有以下模板方便直接套用,以读入命令行参数:

def parse_command_line_arguments():
    # Import the required modules
    import argparse
    # Instantiate the parser
    command_line_arguments_parser = argparse.ArgumentParser()

    # TODO: ADD YOUR ARGUMENTS HERE

    # Add positional arguments
    command_line_arguments_parser.add_argument(
        "my_positional_int_arg",
        type=int,
        help="This is a essential test integer argument",
        default=3,
    )

    # Add optional arguments
    command_line_arguments_parser.add_argument(
        "--my_optional_string",
        type=str,
        help="This is a optional test string argument",
        default="hello world",
    )

    # Add bool arguments(no argument value needed)
    command_line_arguments_parser.add_argument(
        "-v",
        "--verbose",
        action="store_true",
        help="When True, prints out more information",
    )

    # Parse the arguments
    command_line_args = command_line_arguments_parser.parse_args()

    # Return the parsed arguments
    return command_line_args

    # TODO: USE IN YOUR CODE
    # command_line_args = parse_command_line_arguments()
    # print(command_line_args.your_argument_name)

在主代码中使用的参考如下:

command_line_args = parse_command_line_arguments()

# Print all arguments
print(command_line_args)

# Int arguments usage
print(f"Squared value of {command_line_args.my_positional_int_arg} is {command_line_args.my_positional_int_arg**2}")

# Bool arguments usage
if command_line_args.verbose:
    print("This is a verbose print when --verbose is True")

具体解释

对于模板中存在的代码片段,有如下解释:

基本使用

# Import the lib
import argparse
# Instantiate the parser
command_line_arguments_parser = argparse.ArgumentParser()
# Parse the arguments
command_line_args = command_line_arguments_parser.parse_args()

此时无任何程序所需的参数需要输入,通过python <your_script>.py -h进行检验,应当输出如下:

hermanye@hermanye:~/test_ws$ python my_test.py -h
usage: my_test.py [-h]

optional arguments:
  -h, --help  show this help message and exit

添加参数

在实例化ArgumentParser后,使用add_argument()添加需要读取的参数,并指定它的名称、提示说明、参数变量类型、动作等。

位置参数

对于必须要输入的位置参数:

  • 片段
# Add positional arguments
command_line_arguments_parser.add_argument(
    "my_positional_int_arg",
    type=int,
    help="This is a essential test integer argument",
    default=3,
)
  • 示例代码
# Import the lib
import argparse
# Instantiate the parser
command_line_arguments_parser = argparse.ArgumentParser()
# Add positional arguments
command_line_arguments_parser.add_argument(
    "my_positional_int_arg",
    type=int,
    help="This is a essential test integer argument",
    default=3,
)
# Parse the arguments
command_line_args = command_line_arguments_parser.parse_args()
# Print all arguments
print(command_line_args)
# Int arguments usage
print(f"Squared value of {command_line_args.my_positional_int_arg} is {command_line_args.my_positional_int_arg**2}")
  • 测试
python my_test.py 5
# Results
Namespace(my_positional_int_arg=5)
Squared value of 5 is 25

可选参数

对于可选参数,需要在参数名前加上--

  • 片段
# Add optional arguments
command_line_arguments_parser.add_argument(
    "--my_optional_string",
    type=str,
    help="This is a optional test string argument",
    default="hello world",
)
  • 示例代码
# Import the lib
import argparse
# Instantiate the parser
command_line_arguments_parser = argparse.ArgumentParser()
# Add optional arguments
command_line_arguments_parser.add_argument(
    "--my_optional_string",
    type=str,
    help="This is a optional test string argument",
    default="hello world",
)
# Parse the arguments
command_line_args = command_line_arguments_parser.parse_args()
# Print all arguments
print(command_line_args)
# String arguments usage
print(command_line_args.my_optional_string)
  • 测试
# Test 1
python my_test.py

# Test 2
python my_test.py --my_optional_string "This is my test string."
# Results 1
Namespace(my_optional_string='hello world')
hello world

# Results 2
Namespace(my_optional_string='This is my test string.')
This is my test string.

对于不需要具体参数值,而只有True和False的参数,通常使用以下方式赋值:

# Add bool arguments(no argument value needed)
command_line_arguments_parser.add_argument(
    "-v",
    "--verbose",
    action="store_true",
    help="When True, prints out more information",
)
# Bool arguments usage
if command_line_args.verbose:
    print("This is a verbose print when --verbose is True")

使用参数

参数解析后,可以读取整个参数表,也可以读取参数表中具体参数的值:

# Parse the arguments
command_line_args = command_line_arguments_parser.parse_args()

# Print all arguments
print(command_line_args)

# Int arguments usage
print(f"Squared value of {command_line_args.my_positional_int_arg} is {command_line_args.my_positional_int_arg**2}")

# String arguments usage
print(command_line_args.my_optional_string)

# Bool arguments usage
if command_line_args.verbose:
    print("This is a verbose print when --verbose is True")
目录
相关文章
|
18天前
|
存储 人工智能 开发工具
AI助理化繁为简,速取代码参数——使用python SDK 处理OSS存储的图片
只需要通过向AI助理提问的方式输入您的需求,即可瞬间获得核心流程代码及参数,缩短学习路径、提升开发效率。
1247 3
AI助理化繁为简,速取代码参数——使用python SDK 处理OSS存储的图片
|
17天前
|
Java 程序员 C++
【Python】链式、嵌套调用、递归、函数栈帧、参数默认值和关键字参数
【Python】链式、嵌套调用、递归、函数栈帧、参数默认值和关键字参数
20 0
【Python】链式、嵌套调用、递归、函数栈帧、参数默认值和关键字参数
|
6天前
|
存储 C++ Python
[oeasy]python037_ print函数参数_sep分隔符_separator
本文介绍了Python中`print`函数的`sep`参数,即分隔符。通过回顾上文内容,解释了类型与`type`的概念,并强调了参数类型的重要性。文章详细探讨了`print`函数如何使用`sep`参数来分隔输出值,默认分隔符为空格(序号32)。还讨论了如何修改分隔符为其他字符,如冒号,并解释了为何反斜杠需要使用双反斜杠表示。最后,文章追溯了`sep`名称的由来,以及相关词汇的历史背景,如盎格鲁-萨克逊人的武器和语言。
12 0
|
11天前
|
存储 算法 API
Python学习五:函数、参数(必选、可选、可变)、变量、lambda表达式、内置函数总结、案例
这篇文章是关于Python函数、参数、变量、lambda表达式、内置函数的详细总结,包含了基础知识点和相关作业练习。
19 0
|
2月前
|
算法 计算机视觉 Python
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
该文章详细介绍了使用Python和OpenCV进行相机标定以获取畸变参数,并提供了修正图像畸变的全部代码,包括生成棋盘图、拍摄标定图像、标定过程和畸变矫正等步骤。
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
|
28天前
|
存储 Python
30天拿下Python之argparse模块
30天拿下Python之argparse模块
16 0
|
28天前
|
机器学习/深度学习 PyTorch TensorFlow
Python实现深度学习学习率指数衰减的方法与参数介绍
学习率指数衰减提供了一种高效的动态调整学习率的手段,帮助模型在不同训练阶段以不同的学习速度优化,有利于提升模型性能和训练效率。通过合理设置衰减策略中的参数,可以有效地控制学习率的衰减过程,实现更加精确的模型训练调优。
21 0
|
2月前
|
Python
Python变量的作用域_参数类型_传递过程内存分析
理解Python中的变量作用域、参数类型和参数传递过程,对于编写高效和健壮的代码至关重要。正确的应用这些概念,有助于避免程序中的错误和内存泄漏。通过实践和经验积累,可以更好地理解Python的内存模型,并编写出更优质的代码。
26 2
|
2月前
|
Python
python命令行解析模块argparse
python命令行解析模块argparse
|
IDE 开发工具 C++
Python命令行解析:IDE内点击Run运行代码直接得出结果、基于TF flags(或argparse、sys.argv)在Dos内命令行(一条命令)调用代码文件得出结果
Python命令行解析:IDE内点击Run运行代码直接得出结果、基于TF flags(或argparse、sys.argv)在Dos内命令行(一条命令)调用代码文件得出结果