Python脚本传参 -h --help

2024-04-19 20:20
文章标签 python 脚本 help 传参

本文主要是介绍Python脚本传参 -h --help,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

弄清脚本传参,你就不用纠结那么多让你困扰的 - 或 – 参数了,你也可以在你的脚本中写一些让别人一头雾水的 – 参数了。

命名变量传参

如果你想要在传递参数时给它们命名,以便在Python脚本中更容易地识别和使用这些参数,你通常会使用命令行解析库,比如argparseargparse库允许你定义参数的名称、类型、是否必需等,并提供了友好的帮助信息。

下面是一个使用argparse的示例,该示例允许你通过命令行传递命名参数:

script.py

import argparsedef main():parser = argparse.ArgumentParser(description='Process some integers.')parser.add_argument('--name', type=str, help='Your name')parser.add_argument('--age', type=int, help='Your age')args = parser.parse_args()print(f"Name: {args.name}")print(f"Age: {args.age}")if __name__ == '__main__':main()

在Bash中,你可以这样运行这个脚本并传递命名参数:

python script.py --name John --age 30

输出将会是:

Name: John
Age: 30

如果你想要一个更简洁的方式来处理没有命名参数的简单情况,你仍然可以使用sys.argv,但是你可以通过约定来指定参数的顺序或格式。例如,你可以约定第一个参数是名字,第二个参数是年龄:

script.py (使用sys.argv和约定)

import sysdef main():if len(sys.argv) < 3:print("Usage: python script.py <name> <age>")sys.exit(1)name = sys.argv[1]age = sys.argv[2]print(f"Name: {name}")print(f"Age: {age}")if __name__ == '__main__':main()

然后在Bash中运行:

python script.py John 30

输出同样是:

Name: John
Age: 30

请注意,使用sys.argv时,所有的参数都是字符串类型,如果需要其他类型(如整数或浮点数),你需要手动进行转换。而在使用argparse时,参数的类型会在解析时自动转换。

文件传参

如果您想通过命令行参数传入文件,您可以使用 argparse 库的 type=argparse.FileType 功能来自动打开文件。这样,您就不需要手动打开文件了,argparse 会为您处理。

下面是一个示例,展示了如何修改您的代码以接受一个文件作为参数,并读取该文件的内容:

import argparsedef main():parser = argparse.ArgumentParser(description='Process a file.')# 使用 argparse.FileType('r') 来自动打开文件以进行读取parser.add_argument('--file', type=argparse.FileType('r'), help='Path to the file you want to read')parser.add_argument('--name', type=str, help='Your name')parser.add_argument('--age', type=int, help='Your age')args = parser.parse_args()# 由于我们使用了 argparse.FileType,args.file 现在是一个打开的文件对象file_content = args.file.read()  # 读取文件内容args.file.close()  # 关闭文件,尽管在脚本结束时它通常会自动关闭,但显式关闭是一个好习惯print(f"Name: {args.name}")print(f"Age: {args.age}")print(f"File content:\n{file_content}")if __name__ == '__main__':main()

当您运行这个脚本并传入一个文件时,您应该这样做:

python your_script.py --name "John Doe" --age 30 --file path_to_your_file.txt

这里的 path_to_your_file.txt 是您想要读取的文件的路径。argparse 会打开这个文件,并且 args.file 将是一个打开的文件对象,您可以直接从中读取内容。注意,如果文件不存在或者没有读取权限,argparse 会抛出异常。

注意:当您使用 argparse.FileType 时,argparse 会在解析完参数后立即打开文件,这意味着如果您需要额外的错误处理或者不想立即读取文件,那么可能需要采用不同的策略,例如仅接收文件路径作为字符串,然后在需要的时候手动打开文件。

配置文件传参config(.ini、yaml)

处理配置文件(通常是以某种格式存储的键值对或结构化数据的文件,如INI、YAML、JSON等)通常不是通过命令行参数直接传递文件内容来完成的。相反,您会传递配置文件的路径作为命令行参数,然后在您的脚本中读取和处理该文件。

以下是一个示例,展示如何使用 argparse 来接受一个配置文件路径,并使用Python的内置库来读取INI格式的配置文件:

import argparse
import configparserdef main():parser = argparse.ArgumentParser(description='Process a configuration file.')parser.add_argument('--config', type=str, help='Path to the configuration file')args = parser.parse_args()# 使用configparser读取INI格式的配置文件config = configparser.ConfigParser()config.read(args.config)# 读取具体的配置项name = config.get('DEFAULT', 'name')age = config.getint('DEFAULT', 'age')# 打印读取到的配置信息print(f"Name: {name}")print(f"Age: {age}")if __name__ == '__main__':main()

在这个例子中,假设您的配置文件(比如config.ini)看起来像这样:

[DEFAULT]
name = John Doe
age = 30

当您运行脚本时,您需要传递配置文件的路径:

python your_script.py --config path_to_your_config.ini

configparser 会读取这个文件,并允许您通过 get 方法(以及针对特定数据类型的 getint, getfloat, getboolean 等方法)来访问配置中的值。

如果您的配置文件是YAML或JSON格式,您可以使用 PyYAMLjson 库来解析它们。这些库提供了类似的方法来读取和处理配置文件。

请确保您已经安装了必要的库(如 PyYAML),如果需要的话,可以使用 pip 来安装它们:

pip install pyyaml

然后,您可以根据配置文件的格式选择适当的解析方法。例如,对于YAML配置文件,您可以这样做:

import argparse
import yamldef main():parser = argparse.ArgumentParser(description='Process a YAML configuration file.')parser.add_argument('--config', type=str, help='Path to the YAML configuration file')args = parser.parse_args()# 使用yaml库读取YAML格式的配置文件with open(args.config, 'r') as file:config = yaml.safe_load(file)# 读取具体的配置项name = config['name']age = config['age']# 打印读取到的配置信息print(f"Name: {name}")print(f"Age: {age}")if __name__ == '__main__':main()

确保您的YAML配置文件(比如config.yaml)格式正确:

name: John Doe
age: 30

然后,您可以通过命令行传递YAML配置文件的路径来运行脚本:

python your_script.py --config path_to_your_config.yaml

这篇关于Python脚本传参 -h --help的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/918415

相关文章

使用Python将PDF表格自动提取并写入Word文档表格

《使用Python将PDF表格自动提取并写入Word文档表格》在实际办公与数据处理场景中,PDF文件里的表格往往无法直接复制到Word中,本文将介绍如何使用Python从PDF文件中提取表格数据,并将... 目录引言1. 加载 PDF 文件并准备 Word 文档2. 提取 PDF 表格并创建 Word 表格

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA

Python列表的创建与删除的操作指南

《Python列表的创建与删除的操作指南》列表(list)是Python中最常用、最灵活的内置数据结构之一,它支持动态扩容、混合类型、嵌套结构,几乎无处不在,但你真的会创建和删除列表吗,本文给大家介绍... 目录一、前言二、列表的创建方式1. 字面量语法(最常用)2. 使用list()构造器3. 列表推导式

Python使用Matplotlib和Seaborn绘制常用图表的技巧

《Python使用Matplotlib和Seaborn绘制常用图表的技巧》Python作为数据科学领域的明星语言,拥有强大且丰富的可视化库,其中最著名的莫过于Matplotlib和Seaborn,本篇... 目录1. 引言:数据可视化的力量2. 前置知识与环境准备2.1. 必备知识2.2. 安装所需库2.3

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

Python+FFmpeg实现视频自动化处理的完整指南

《Python+FFmpeg实现视频自动化处理的完整指南》本文总结了一套在Python中使用subprocess.run调用FFmpeg进行视频自动化处理的解决方案,涵盖了跨平台硬件加速、中间素材处理... 目录一、 跨平台硬件加速:统一接口设计1. 核心映射逻辑2. python 实现代码二、 中间素材处

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Python实现快速扫描目标主机的开放端口和服务

《Python实现快速扫描目标主机的开放端口和服务》这篇文章主要为大家详细介绍了如何使用Python编写一个功能强大的端口扫描器脚本,实现快速扫描目标主机的开放端口和服务,感兴趣的小伙伴可以了解下... 目录功能介绍场景应用1. 网络安全审计2. 系统管理维护3. 网络故障排查4. 合规性检查报错处理1.

Python轻松实现Word到Markdown的转换

《Python轻松实现Word到Markdown的转换》在文档管理、内容发布等场景中,将Word转换为Markdown格式是常见需求,本文将介绍如何使用FreeSpire.DocforPython实现... 目录一、工具简介二、核心转换实现1. 基础单文件转换2. 批量转换Word文件三、工具特性分析优点局

Python中4大日志记录库比较的终极PK

《Python中4大日志记录库比较的终极PK》日志记录框架是一种工具,可帮助您标准化应用程序中的日志记录过程,:本文主要介绍Python中4大日志记录库比较的相关资料,文中通过代码介绍的非常详细,... 目录一、logging库1、优点2、缺点二、LogAid库三、Loguru库四、Structlogphp