深度学习:使用argparse 模块

       在深度学习中,结合 Bash 脚本和 argparse 模块,可以实现高效的任务自动化和参数管理。Bash 脚本可以用来调度任务和管理环境,而 argparse 模块可以用来解析命令行参数控制深度学习模型的训练和评估过程。

1.argparse 模块

argparse 模块是 Python 标准库中的一个模块,用于解析命令行参数它可以帮助开发者轻松地编写用户友好的命令行接口,使得程序可以通过命令行参数来接受用户输入,并根据这些输入执行相应的功能。

argparse 模块的主要功能

  1. 定义命令行参数:可以定义位置参数和可选参数,以及它们的类型、默认值和帮助信息。
  2. 解析命令行参数:自动解析命令行输入,并将其转换为相应的数据类型。
  3. 生成帮助和使用信息:自动生成帮助信息,用户可以通过 -h--help 选项查看。

使用 argparse 模块的步骤

  1. 创建 ArgumentParser 对象:这是解析器的核心对象。
  2. 添加参数:使用 add_argument 方法添加命令行参数。
  3. 解析参数:使用 parse_args 方法解析命令行输入。
  4. 使用参数:解析后的参数可以作为属性访问并在程序中使用。

示例代码

下面是一个使用 argparse 模块的基本示例:

import argparsedef main():# 创建 ArgumentParser 对象parser = argparse.ArgumentParser(description='这是一个示例程序')# 添加参数parser.add_argument('filename', type=str, help='文件的名称')parser.add_argument('--verbose', '-v', action='store_true', help='输出详细信息')parser.add_argument('--count', '-c', type=int, default=1, help='重复次数')# 解析参数args = parser.parse_args()# 使用参数if args.verbose:print(f'Processing file: {args.filename}')print(f'Repeat count: {args.count}')# 模拟处理文件for i in range(args.count):print(f'Processing {args.filename} - iteration {i + 1}')if __name__ == '__main__':main()

运行命令:

python script.py example.txt -v -c 3

输出示例:

Processing file: example.txt
Repeat count: 3
Processing example.txt - iteration 1
Processing example.txt - iteration 2
Processing example.txt - iteration 3

参数类型

  • 位置参数:必须提供,按位置传递。例如,上面的 filename
  • 可选参数:不必须提供,通常以 --- 开头,例如 --verbose--count

处理布尔选项

布尔选项通常使用 action='store_true'action='store_false'

parser.add_argument('--verbose', '-v', action='store_true', help='输出详细信息')

设置默认值

可以使用 default 参数来设置默认值:

parser.add_argument('--count', '-c', type=int, default=1, help='重复次数')

帮助信息

argparse 会自动生成帮助信息。用户可以使用 -h--help 选项来查看:

python script.py -h

输出:

usage: script.py [-h] [--verbose] [--count COUNT] filename这是一个示例程序positional arguments:filename            文件的名称optional arguments:-h, --help          show this help message and exit--verbose, -v       输出详细信息--count COUNT, -c   重复次数

子命令

通过 add_subparsers 方法,可以轻松地处理子命令:

import argparsedef main():parser = argparse.ArgumentParser(description='带有子命令的示例程序')# 添加子命令解析器subparsers = parser.add_subparsers(dest='command', help='子命令')# 添加子命令 'foo'parser_foo = subparsers.add_parser('foo', help='foo 子命令的帮助信息')parser_foo.add_argument('--bar', type=int, required=True, help='bar 参数')# 添加子命令 'baz'parser_baz = subparsers.add_parser('baz', help='baz 子命令的帮助信息')parser_baz.add_argument('--qux', type=str, help='qux 参数')# 解析参数args = parser.parse_args()# 处理子命令if args.command == 'foo':print(f'执行 foo 子命令,bar 参数值为 {args.bar}')elif args.command == 'baz':print(f'执行 baz 子命令,qux 参数值为 {args.qux}')else:parser.print_help()if __name__ == '__main__':main()

运行命令:

python script.py foo --bar 123
python script.py baz --qux hello

输出示例:

执行 foo 子命令,bar 参数值为 123
执行 baz 子命令,qux 参数值为 hello

总结

argparse 模块是一个强大的工具,用于解析命令行参数,提供了丰富的功能来处理不同类型的参数和选项,使得命令行工具的开发更加简便和灵活。通过定义和解析参数,开发者可以方便地从命令行获取用户输入,并在程序中使用这些输入来执行相应的操作。

2. 使用argparse 模块 

python3 utils/create_indexes.py create_indexes \--waveforms_hdf5_path=$WORKSPACE"/hdf5s/waveforms/eval.h5" \--indexes_hdf5_path=$WORKSPACE"/hdf5s/indexes/eval.h5

这段代码使用 argparse 模块解析命令行参数,并执行指定的操作。具体来说,代码的作用是调用一个 Python 脚本 create_indexes.py,执行 create_indexes 子命令,并传递两个参数:waveforms_hdf5_pathindexes_hdf5_path。下面详细分析这段代码的各个部分。

代码拆解和分析

1. 调用 Python 脚本
 
python3 utils/create_indexes.py create_indexes
2. 传递命令行参数
--waveforms_hdf5_path=$WORKSPACE"/hdf5s/waveforms/eval.h5" \
--indexes_hdf5_path=$WORKSPACE"/hdf5s/indexes/eval.h5"

这部分代码传递了两个命令行参数:

  • --waveforms_hdf5_path:指定包含波形数据的 HDF5 文件路径。
  • --indexes_hdf5_path:指定要生成的索引 HDF5 文件路径。

这两个路径是基于环境变量 WORKSPACE 构建的,$WORKSPACE 变量表示工作空间的路径。

环境变量和路径拼接

假设 WORKSPACE 变量的值为 "/home/user/project",则上述路径在运行时会被解析为:

  • --waveforms_hdf5_path="/home/user/project/hdf5s/waveforms/eval.h5"
  • --indexes_hdf5_path="/home/user/project/hdf5s/indexes/eval.h5"

create_indexes.py 脚本的实现

为了更好地理解这段代码,我们需要假设 create_indexes.py 的部分实现。通常,这个脚本会使用 argparse 模块解析命令行参数,并根据参数调用相应的函数。

示例的 create_indexes.py 实现
import argparsedef create_indexes(args):waveforms_hdf5_path = args.waveforms_hdf5_pathindexes_hdf5_path = args.indexes_hdf5_path# 假设有一个函数 load_waveforms 用于加载波形数据waveforms = load_waveforms(waveforms_hdf5_path)# 假设有一个函数 create_and_save_indexes 用于创建索引并保存到 HDF5 文件create_and_save_indexes(waveforms, indexes_hdf5_path)def load_waveforms(path):# 从 HDF5 文件中加载波形数据的示例实现import h5pywith h5py.File(path, 'r') as f:waveforms = f['waveforms'][:]return waveformsdef create_and_save_indexes(waveforms, path):# 创建索引并保存到 HDF5 文件的示例实现import h5pyindexes = generate_indexes(waveforms)  # 生成索引的示例函数with h5py.File(path, 'w') as f:f.create_dataset('indexes', data=indexes)def generate_indexes(waveforms):# 假设生成索引的示例实现indexes = [i for i in range(len(waveforms))]return indexesif __name__ == '__main__':parser = argparse.ArgumentParser(description='创建索引')subparsers = parser.add_subparsers(dest='mode')parser_create_indexes = subparsers.add_parser('create_indexes')parser_create_indexes.add_argument('--waveforms_hdf5_path', type=str, required=True, help='波形数据 HDF5 文件的路径')parser_create_indexes.add_argument('--indexes_hdf5_path', type=str, required=True, help='索引 HDF5 文件的路径')args = parser.parse_args()if args.mode == 'create_indexes':create_indexes(args)else:raise ValueError('不支持的子命令')

运行代码时的过程

  1. 执行命令行:执行命令行 python3 utils/create_indexes.py create_indexes --waveforms_hdf5_path="/home/user/project/hdf5s/waveforms/eval.h5" --indexes_hdf5_path="/home/user/project/hdf5s/indexes/eval.h5"

  2. 解析参数argparse 模块解析命令行参数,将 waveforms_hdf5_pathindexes_hdf5_path 的值存储在 args 对象中。

  3. 调用函数:根据子命令 create_indexes,调用 create_indexes(args) 函数。

  4. 加载波形数据:在 create_indexes 函数中,调用 load_waveforms 函数从指定的 HDF5 文件中加载波形数据。

  5. 创建并保存索引:调用 create_and_save_indexes 函数,根据波形数据生成索引,并将索引保存到指定的 HDF5 文件中。

总结

这段代码展示了如何使用 argparse 模块解析命令行参数并执行特定操作。通过结合命令行参数和脚本逻辑,可以方便地实现复杂的任务自动化流程。上述示例详细解释了命令行参数的传递和处理方式,有助于更好地理解和使用 argparse 模块。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/27047.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python 显示笔记本电脑的电池状态和百分比

方法一: import psutil import psutil battery psutil.sensors_battery() if battery is None:print("No battery is found.")exit() print (battery) percentagebattery.percent print(f"Battery Percentage: {percentage}%")Battery的信息…

『大模型笔记』缩放定律(scaling laws)是由记忆而非智力解释的吗?

MAC 文章目录 一. 缩放定律(scaling laws)是由记忆而非智力解释的吗?1. 视频原文内容2. 要点总结一般智能的定义规模最大化的论点性能衡量的方式及其影响大语言模型的基准测试大语言模型的本质与记忆基准测试插值的概念与基准测试实例人类和模型的推理与样本效率二. 参考文献一…

期末测试2--函数题---指针链表如何输出?

总结写代码时候遇到的问题 1.遍历指针链表 指针head在做for循环遍历的时候 for(head, head!NULL;head) head不能 for(head,head!NULL;headhead->next)-------正确的写法 int i; for(ihead;head!NULL;headhead->next) i 是 int 类型的&#x…

chrome浏览器设置--disable-web-security解决跨域

在开发人员于后台进行接口测试的时候,老是遇到跨域问题,这时前端总是会让后台添加跨域请求头来允许跨域请求,今天介绍一个简单的方法跨过这一步操作的设置。 –disable-web-security参数,禁用同源策略,利于开发人员本…

STM32串口空闲中断接收不定长数据

目录 1. 开启串口空闲中断2. 合理开关中断3. 串口发送函数 1. 开启串口空闲中断 最近接触到的 Modbus RTU 项目使用到了串口接收中断和空闲中断。记录一下 初始化可以直接套用正点原子的初始化,只需要添加一行即可 USART_ITConfig(USART1, USART_IT_IDLE, ENABLE)…

Dockerfile制作能够ssh的ubuntu和centos7系统

目录 一.制作ubuntu系统 1.Dockerfile内容如下 2.运行容器并验证 二.制作centos7系统 1.Dockerfile内容如下 2.验证并测试 一.制作ubuntu系统 要求:制作一个能够远程ssh的ubuntu操作系统镜像,要求通过该镜像运容器后,内部拥有一些自动…

嵌入式系统复习(一)

第一章 嵌入式系统的定义、特点 嵌入式系统是以应用为中心,以计算机技术为基础,软件硬件可裁剪,适应应用系统对功能、可靠性、成本、体积、功耗严格要求的专用计算机系统。 特点:嵌入性 专用性 计算机系统 嵌入式系统典型组成…

[Shell编程学习路线]——探讨Shell中变量的作用范围(export)

🏡作者主页:点击! 🛠️Shell编程专栏:点击! ⏰️创作时间:2024年6月14日10点14分 🀄️文章质量:95分 文章目录 ————前言———— 定义变量: 输出变…

acast,跨平台的asciinema终端录屏工具

项目地址:https://github.com/gvcgo/asciinema 项目文档:https://github.com/gvcgo/asciinema/blob/main/docs/README_CN.md asciinema [as-kee-nuh-muh] 是一个免费开源的终端会话录制和分享工具。 你可以访问 asciinema.org 了解更多关于 asciinema …

【Mars3d】config.json中的蓝色底图map.basemap = 2017代码实现

本身的地图效果: Mars3d的蓝色地图效果: 关键代码: basemaps: [{name: "高德电子",icon: "img/basemaps/gaode_vec.png",type: "gaode",layer: "vec",show: true,invertColor: true,filterColor: &q…

Slice用法举例Python

Slice用法举例Python 在Python中,slice(切片)是一个强大的工具,用于处理序列类型的数据,如列表、元组、字符串等。slice提供了一种简洁而高效的方式来获取序列的子集或修改序列的某些部分。下面,我们将从四…

Java 注释

在编程领域,良好的代码注释通常被认为是高效开发的黄金规则之一。特别是在 Java 编程语言中,注释不仅帮助开发者阐述代码功能,提升代码可读性,还是生成技术文档的重要基础。本文将深入探讨 Java 中的注释,解析其种类和…

LLM 大模型学习:数据预处理、模板设计以

在模型训练过程中,数据及数据处理是最为重要的工作之一。在当前模型训练流程趋于成熟的情况下,数据集的好坏,是决定了该次训练能否成功的最关键因素。 在上一篇中,我们提到了模型训练的基本原理是将文字转换索引再转换为对应的向…

Android.mk中LOCAL_NDK_STL_VARIANT标签定义类型都有哪些?

在 Android NDK(Native Development Kit)中,Android.mk 文件是用于定义编译本地代码(如 C/C)的 Makefile 片段。其中,LOCAL_NDK_STL_VARIANT 是一个变量,用于指定在编译时使用的 STL&#xff08…

机器学习python实践——数据“相关性“的一些补充性个人思考

在上一篇“数据白化”的文章中,说到了数据“相关性”的概念,但是在统计学中,不仅存在“相关性”还存在“独立性”等等,所以,本文主要对数据“相关性”进行一些补充。当然,如果这篇文章还能入得了各位“看官…

【React】Lodash---groupBy() 分组

例子 _.groupBy([6.1, 4.2, 6.3], Math.floor); // > { 4: [4.2], 6: [6.1, 6.3] }// The _.property iteratee shorthand. _.groupBy([one, two, three], length); // > { 3: [one, two], 5: [three] }思路分析 来源 定义一个名为groupBy的方法,通过扩展Ar…

OpenAI最强大模型ChatGPT-4o,论文降重小技巧,国内直接使用

一、万字论文,从0到1,只需1小时 通过OpenAI5月14日1点发布的最新大模型ChatGPT4o: 1小时即可完成万字论文的编写通过GPT定制的降重大模型“中文论文降重”,2小时即可完成一篇优质的、查重率较低的万字论文。 在ChatGPT4o对话框中…

【全开源】多功能投票小程序源码(Uniapp+ThinkPHP+FastAdmin)

💥**【热门推荐】多功能投票小程序,一键解决你的选择难题!**💥 基于ThinkPHPFastAdminUniapp开发的多功能系统,支持图文投票、自定义选手报名内容、自定义主题色、礼物功能(高级授权)、弹幕功能(高级授权)、会员发布、…

[UUCTF 2022 新生赛]爱丽丝梦境的兔子(古典密码)

题目: U2FsdGVkX19ixL7s5HryOhyL5oSScYGNVBVWlsUMYQwTRniXreqeSp/iTHtkcxt qicNL4xpHc5X34Daat7ixqkZMpU4JV9USOKKTAw9HJfGnoDzFF/JY0gzJpxgmW1X 4nXktQ4J7OM14EMcTrhPDIOfG2VDJr4yViWc/vNS8np1IFeIRXMoWGAJHuI8IOVG tXi2JX6hTseYkJc2LGHJkLQ0WDW67RyhPC3vOwmJHOs/w…

TF-IDF算法:从文本中发现价值的黄金法则

TF-IDF算法 一、简介二、TF-IDF算法原理2.1 词频(TF)2.2 逆文档频率(IDF)2.3 TF-IDF的计算 三、TF-IDF算法应用3.1 搜索引擎3.2 文本分类3.3 信息提取3.4 文本摘要 四、TF-IDF算法的改进4.1、TF-IDF算法的改进4.1.1. 基于词的权重…