ExDark数据集标签转yolo格式(易懂)

ExDark数据集标签转yolo格式(易懂)

一、前言

知道大家为何而来,因此作者不必废话直接上代码。代码已经详细注释,如果读者还有不懂的地方,在评论区留言,我将在48小时内回复你(如果我没毕业的话)。

二、代码

import os
import cv2
import re# 定义类别列表
categSrces = ['Bicycle', 'Boat', 'Bottle', 'Bus', 'Car', 'Cat', 'Chair', 'Cup', 'Dog', 'Motorbike', 'People', 'Table']# 函数:将类别名称转换为类别索引
def Get_Cls_Index(Cls_Name):if Cls_Name in categSrces:return categSrces.index(Cls_Name)else:raise ValueError(f"Class '{Cls_Name}' not found in the category list.")# 函数:将标签文件内容转换为 YOLO 格式
def Convert_to_yolo_label(Img_Folder, Src, Dst):# 检查源文件夹是否存在if not os.path.exists(Src):raise ValueError("Src does not exist.")# 检查目标文件夹是否存在,如果不存在,则创建它if not os.path.exists(Dst):  os.makedirs(Dst)for file in os.listdir(Src):with open(os.path.join(Src, file), 'r') as LabelFile:# 正则表达式匹配match = re.findall('([0-9]+_[0-9]+)(.[a-zA-z]+)(.[a-zA-Z]+)', file)[0]Prefix = match[0]  # 真实文件名(不带扩展名)Img_Format = match[1]  # 图像格式lines = LabelFile.readlines()  # 读取源标签文件内容Yolo_File_Content = []  # 存储转换后的标签文件内容(每一个列表元素是一个目标的标签)Save_File_Name = os.path.join(Dst, Prefix + '.txt')  # 存储转换后的标签文件路径# 读取对应的图片,并获取形状参数(高和宽)img = cv2.imread(os.path.join(Img_Folder, Prefix+Img_Format))img_height, img_width, _ = img.shape  # 获取图像的高度和宽度for line in lines[1:]:  # 跳过文件版本行# 解析标签文件内容,将标签信息读取出来Labelinfo = line.strip().split()# 解析标签文件内容,将标签信息读取出来Cls_Name = Labelinfo[0]x_min = float(Labelinfo[1])y_min = float(Labelinfo[2])box_width = float(Labelinfo[3])box_height = float(Labelinfo[4])# 计算Yolo标签格式:类别索引 标签框的中心点x坐标 标签框的中心点y坐标 宽度 高度# 最后每一个参数计算参数都要归一化,后面除以高或宽就是为了归一化处理Cls_Index = Get_Cls_Index(Cls_Name)x_center = (x_min + box_width / 2) / img_width y_center = (y_min + box_height / 2) / img_heightnorm_width = box_width / img_widthnorm_height = box_height / img_height# 构建 YOLO 格式的标签行,并保存yolo_label = f"{Cls_Index} {x_center:.6f} {y_center:.6f} {norm_width:.6f} {norm_height:.6f}\n"Yolo_File_Content.append(yolo_label)# 将转换后的标签文件内容写入目标文件with open(Save_File_Name, 'w') as TargetFile:TargetFile.writelines(Yolo_File_Content)# 定义图像文件夹路径、源标签文件目录路径和目标标签文件目录路径
Img_Folder = r'E:\Datasets\ExDark\images'
Src = r'E:\Datasets\ExDark\Annotations'
Dst = r'E:\Datasets\ExDark\Annotations_yolo'# 调用函数,将ExDark的标签文件转换为 YOLOv 格式
Convert_to_yolo_label(Img_Folder, Src, Dst)

三、注意事项

  • 代码拷贝后记得修改路径
  • 文章对于源标签文件名的各部分(真实文件名图像格式文本文件后缀)提取使用了正则表达式
  • 正则表达式是非常强大的东西,本着授人以鱼不如授人以渔的初心和目的,希望大家能理解上述正则表达式,这里我提供了大家网页学习的路径
    • 正则表达式 – 语法 | 菜鸟教程 (runoob.com)
  • 如果嫌麻烦,那么下面是简单的对正则表达式语法的介绍(已足够读者理解代码中的正则表达式)
    • 匹配字符
      • .:匹配任意字符(除了换行符)
      • \w:匹配任意字母数字字符(相当于 [a-zA-Z0-9_]
      • \W:匹配任意非字母数字字符
      • \d:匹配任意数字字符(相当于 [0-9]
      • \D:匹配任意非数字字符
      • \s:匹配任意空白字符(相当于 [ \t\n\r\f\v]
      • \S:匹配任意非空白字符
    • 边界匹配
      • ^:匹配字符串的开头
      • $:匹配字符串的结尾
      • \b:匹配一个单词边界
      • \B:匹配非单词边界
    • 字符集
      • [abc]:匹配方括号内的任意一个字符(此处为 abc
      • [^abc]:匹配不在方括号内的任意一个字符
      • [a-z]:匹配小写字母范围内的任意一个字符
      • [A-Z]:匹配大写字母范围内的任意一个字符
      • [0-9]:匹配数字范围内的任意一个字符
    • 量词
      • *:匹配前一个字符零次或多次
      • +:匹配前一个字符一次或多次
      • ?:匹配前一个字符零次或一次
      • {n}:匹配前一个字符恰好 n
      • {n,}:匹配前一个字符至少 n
      • {n,m}:匹配前一个字符至少 n 次,但不超过 m
    • 分组和引用
      • ():匹配括号内的表达式,并记住匹配的文本
      • |:匹配 | 左右任意一个表达式
      • \num:匹配 num 所表示的分组
      • (?P<name>...):匹配 ... 并将匹配结果命名为 name
      • (?P=name):引用命名为 name 的分组匹配结果
    • 特殊序列
      • \A:匹配字符串的开头
      • \Z:匹配字符串的结尾
      • \:将后面的字符转义为原始字符
      • \g<name>:引用命名为 name 的分组匹配结果
      • \number:引用编号为 number 的分组匹配结果

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

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

相关文章

接口综合管理站iGR-IMS的产品特点

接口综合管理站iGR-IMS的产品特点可以归纳为以下几点&#xff1a; 1. 高安全性&#xff1a;产品选用Linux作为软件基础平台&#xff0c;同时能够配合电力专用隔离装置&#xff0c;实现跨安全区的单向数据传输&#xff0c;保证了数据传输的安全性。 2. 高性能&#xff1a;产品…

开源之夏|祝贺MatrixOne开源社区项目中选同学!

在本届「开源之夏 2024」活动中&#xff0c;MatrixOne开源社区共计上线3个项目任务&#xff0c;最终有 3位同学成功突围。接下来让我们看看每个项目的详细中选情况&#xff1a; 中选学生公示 项目名称&#xff1a;基于大语言模型的操作系统任务自动识别&#xff0c;拆解&#…

Stable Diffusion教程:如何实现人脸一致

在AI绘画中&#xff0c;一直都有一个比较困难的问题&#xff0c;就是如何保证每次出图都是同一个人。今天就这个问题分享一些个人实践&#xff0c;大家和我一起来看看吧。 一. 有哪些实现方式 方式1&#xff1a;固定Seed种子值。 固定Seed种子值出来的图片人物确实可以做到一…

canal+mq将数据同步到redis中的一些类型转换问题

在将 Canal 捕获到的数据库变更同步到 RabbitMQ 时&#xff0c;通常需要将变更事件的数据从 Java 对象转换为一种通用的数据格式&#xff0c;如 JSON。这样可以确保数据在不同系统之间传递时的兼容性。以下是将 Canal 数据同步到 RabbitMQ 并进行数据类型转换的示例代码。 1. …

Cherno 游戏引擎笔记记录(33~45)

好久不见。 My Github REPO(GitHub - JJJJJJJustin/Nut: The game_engine which learned from Cherno) 源码笔记&#xff0c;希望帮到你 :-} -------------------相机&原理---------- 》》》》查看这两篇说明&#xff0c;一个是坐标系统&#xff0c;一个是摄像机 &#xf…

通过Spring Boot结合实时流媒体技术对考试过程进行实时监控

本章将深入探讨考试系统中常见的复杂技术问题&#xff0c;并提供基于Spring Boot 3.x的解决方案。涵盖屏幕切换检测与防护、接打电话识别处理、行为监控摄像头使用、网络不稳定应对等&#xff0c;每篇文章详细剖析问题并提供实际案例与代码示例&#xff0c;帮助开发者应对挑战&…

大语言模型系列-Transformer(二)

Transformer 模型的入门可以从以下几个方面开始&#xff1a; 1. 理解基本概念 序列到序列&#xff08;Sequence-to-Sequence&#xff09;任务&#xff1a;Transformer 模型主要用于这类任务&#xff0c;如机器翻译、文本摘要等。注意力机制&#xff08;Attention Mechanism&a…

PyTorch基础(23)-- Tensor.scatter_()方法

一、前言 本次要介绍的函数为Tensor.scatter_函数&#xff0c;也是PyTorch中常用的函数之一&#xff0c;但遗憾的是&#xff0c;我想在网络上查询该函数的用法时&#xff0c;大部分的文章都是直接给出一个示例&#xff0c;看完之后&#xff0c;其中的原理我还是无法理解&#…

python生成器在读取接口用例中应用解析

Python生成器Generator Python生成器&#xff08;Generator&#xff09;是一种特殊类型的函数&#xff0c;它可以通过yield语句逐步生成值。 生成器提供了一种延迟计算的方式&#xff0c;可以逐步产生结果&#xff0c;而不是一次性生成所有的值。 1、生成器原理&#xff1a; …

Java中的AOP编程详解

Java中的AOP编程详解 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 1. 什么是AOP&#xff1f; AOP&#xff08;Aspect-Oriented Programming&#xff0c;面…

2024年【A特种设备相关管理(A4电梯)】试题及解析及A特种设备相关管理(A4电梯)模拟试题

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 A特种设备相关管理&#xff08;A4电梯&#xff09;试题及解析根据新A特种设备相关管理&#xff08;A4电梯&#xff09;考试大纲要求&#xff0c;安全生产模拟考试一点通将A特种设备相关管理&#xff08;A4电梯&#x…

Mac密室逃脱游戏推荐:Escape Simulator for mac安装包

Escape Simulator 是一款逃生模拟游戏&#xff0c;玩家在游戏中需要寻找线索、解决谜题&#xff0c;以逃离各种房间或环境。这种类型的游戏通常设计有多个关卡或场景&#xff0c;每个场景都有不同的设计和难度。 在 Escape Simulator 中&#xff0c;玩家的目标通常是找到出口或…

算法力扣刷题——总结篇【四】和string类详解

前言 字符串章节部分跟随学习结束&#xff0c;作出总结。 一、题目及方法总结 &#xff08;1&#xff09;反转字符串&#xff1a;双指针法。 反转全部字符串&#xff0c;i在开头&#xff0c;j在结尾&#xff1b;判断条件i < j ;每隔2k反转前k个字符&#xff0c;i改成i 2…

PermissionError: [Errno 13] Permission denied: ‘/tmp/gradio...‘

无管理员权限修改 Gradio 默认路径遇到的 PermissionError 问题 在使用 Gradio 进行开发和部署时&#xff0c;可能会遇到如下报错&#xff1a; PermissionError: [Errno 13] Permission denied: /tmp/gradio/tmpzo5r9g_k.png报错分析 上述报错是由于在没有权限访问指定路径时…

东方韵味:红酒与茶道的很好邂逅

在古老的东方&#xff0c;茶道与红酒各自承载着深厚的文化底蕴和历史传承。当这两大传统文化碰撞、交融&#xff0c;仿佛展开了一幅绚烂多姿的画卷&#xff0c;既展现了东方的神秘韵味&#xff0c;又融入了红酒的异国风情。今天&#xff0c;就让我们一同探索这场红酒与茶道的很…

详解微服务应用灰度发布最佳实践

作者&#xff1a;子丑 本次分享是站在 DevOps 视角的灰度发布实践概述&#xff0c;主要内容包括以下四个方面&#xff1a; 第一&#xff0c;灰度发布要解决的问题&#xff1b; 第二&#xff0c;灰度发布的四种典型场景&#xff1b; 第三&#xff0c;如何把灰度发布融入到应…

关于std::memory_order_consume

原文&#xff1a;https://preshing.com/20140709/the-purpose-of-memory_order_consume-in-cpp11/ 翻译&#xff1a;C11中memory_order_consume的目的 https://blog.csdn.net/netyeaxi/article/details/80718781 文章中有这样一个例子&#xff1a; g Guard.load(memory_ord…

terminals database is inaccessible

在复制虚拟环境后&#xff0c;执行clean操作经常报以上错误 解决方案如下&#xff1a; vim ~/.bashrc alias clear"TERMxterm /usr/bin/clear" source ~/.bashrc

2024-07-03_外语学习

文章目录 1. SSCC&#xff08;Serial Shipping Container Code&#xff09;2. Serial读音词源ser-01ser-02 3. routing instruction在计算领域在物流领域Routing Instruction 的词源分析RoutingInstruction 1. SSCC&#xff08;Serial Shipping Container Code&#xff09; 在…

2024年07月03日 Redis部署方式和持久化

Redis持久化方式&#xff1a;RDB和AOF&#xff0c;和混合式 RDB&#xff1a;周期备份模式&#xff0c;每隔一段时间备份一份快照文件&#xff0c;从主线程Fork一个备份线程出来备份&#xff0c;缺点是会造成数据的丢失。 AOF&#xff1a;日志模式&#xff0c;每条命令都以操作…