【数据标注】使用LabelImg标注YOLO格式的数据(案例演示)

2024-04-27 16:28

本文主要是介绍【数据标注】使用LabelImg标注YOLO格式的数据(案例演示),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • LabelImg介绍
    • LabelImg安装
    • LabelImg界面
    • 标注常用的快捷键
    • 标注前的一些设置
    • 案例演示
    • 检查YOLO标签中的标注信息是否正确
    • 参考文章


LabelImg介绍

LabelImg是目标检测数据标注工具,可以标注两种格式:

  • VOC标签格式,标注的标签存储在xml文件
  • YOLO标签格式,标注的标签存储在txt文件中

LabelImg官网:

labelImg的GitHub链接:https://github.com/HumanSignal/labelImg


LabelImg安装

在Anaconda创建的虚拟环境中使用pip安装LabelImg
1、打开 Anaconda Prompt
2、创建一个虚拟环境

conda create -n use_labelimg python=3.6

3、激活虚拟环境

conda activate use_labelimg

4、使用pip安装LabelImg(有挂代理/梯子记得关掉)

pip install labelimg -i https://pypi.tuna.tsinghua.edu.cn/simple

5、执行以下命令打开LabelImg

labelimg

在这里插入图片描述


LabelImg界面

在这里插入图片描述


标注常用的快捷键

  • W:调出标注的十字架,开始标注
  • A:切换到上一张图片
  • D:切换到下一张图片
  • Ctrl+S:保存标注好的标签
  • del:删除标注的矩形框
  • Ctrl+鼠标滚轮:按住Ctrl,然后滚动鼠标滚轮,可以调整标注图片的显示大小
  • Ctrl+u:选择要标注图片的文件夹
  • Ctrl+r:选择标注好的label标签存放的文件夹
  • ↑→↓←:移动标注的矩形框的位置

标注前的一些设置

点击View显示如下图,然后把如下的几个选项勾上:

  • Auto Save mode:当你切换到下一张图片时,就会自动把上一张标注的图片标签自动保存下来,这样就不用每标注一样图片都按Ctrl+S保存一下了
  • Display Labels:标注好图片之后,会把框和标签都显示出来
  • Advanced Mode:这样标注的十字架就会一直悬浮在窗口,不用每次标完一个目标,再按一次W快捷键,调出标注的十字架。

在这里插入图片描述


案例演示

1、假设在我的 green_plate文件夹 中已经存放了所要进行标注的车牌图片
在这里插入图片描述
2、在 LabelImg界面 通过 Open Dir 导入 green_plate文件夹
在这里插入图片描述
3、在 LabelImg界面 通过 Change Save Dir 选择 存放标注好图片的文件夹路径
在这里插入图片描述

4、在 LabelImg界面 点击 View 进行标注前的一些设置
5、设置标注的文件格式为YOLO
在这里插入图片描述
6、按W键调出标注的十字架,开始标注

可通过Ctrl+鼠标滚轮调整标注图片的显示大小,方便对目标进行标注
在这里插入图片描述

7、对一张图片标注完成后,按D键切换到下一张图片继续标注
8、如果需要对一个标注好的矩形框进行删除,可以按以下图片中的操作进行
在这里插入图片描述
9、重复以上步骤直至所有的图片标注完成
10、在存放标注好图片的文件夹中查看标注好的文件
在这里插入图片描述


检查YOLO标签中的标注信息是否正确

通过读取图像文件和相应的标签文件来绘制边界框,并在窗口中显示带有边界框的图像。
如果边界框的位置和大小与预期相符,那么可以认为YOLO格式的标签是正确的。

"""
文件名: CheckYOLOLabels.py
功能描述: 检查YOLO标签中的标注信息是否正确
"""import os
import cv2
import matplotlib.pyplot as plt
import numpy as npdef listPathAllfiles(dirname):"""遍历指定目录下的所有文件并返回一个包含这些文件路径的列表。"""result = []for maindir, subdir, file_name_list in os.walk(dirname):for filename in file_name_list:apath = os.path.join(maindir, filename)result.append(apath)return resultif __name__ == '__main__':# YOLO图片文件的保存路径imagespath = "DeepLearningProjects\\green_plate"# YOLO标签文件的保存路径labelspath = "DeepLearningProjects\\process_green_plate"# 获取所有标签文件的路径labelsFiles = listPathAllfiles(labelspath)# 逆序遍历标签文件,因为通常最新的文件在最后for lbf in labelsFiles[::-1]:# 读取标签文件的每一行,并将其分割成一个列表labels = open(lbf, "r").readlines()labels = list(map(lambda x: x.strip().split(" "), labels))# 构造对应的图片文件名imgfileName = os.path.join(imagespath, os.path.basename(lbf)[:-4] + ".jpg") # .jpg# 从文件中读取图片,cv2.imdecode函数可以将字节流解码为图像img = cv2.imdecode(np.fromfile(imgfileName, dtype=np.uint8), 1)# 遍历每个标签for lbs in labels:# 将标签字符串转换为浮点数,并去掉类别索引lb = list(map(float, lbs))[1:]# 根据标签计算边界框的左上角和右下角坐标x1 = int((lb[0] - lb[2] / 2) * img.shape[1])y1 = int((lb[1] - lb[3] / 2) * img.shape[0])x2 = int((lb[0] + lb[2] / 2) * img.shape[1])y2 = int((lb[1] + lb[3] / 2) * img.shape[0])# 在图像上绘制边界框cv2.rectangle(img, (x1, y1), (x2, y2), (0, 0, 255), 5)# 调整图像大小,使其最大边长为600像素ratio = 600 / min(img.shape[0:2])img = cv2.resize(img, dsize=(int(img.shape[1] * ratio), int(img.shape[0] * ratio)))# 显示带有边界框的图像cv2.imshow("Image", img)# 等待用户按键,按任意键继续cv2.waitKey()# 关闭所有OpenCV创建的窗口cv2.destroyAllWindows()

参考文章

目标检测使用LabelImg标注VOC数据格式和YOLO数据格式——LabelImg使用详细教程

这篇关于【数据标注】使用LabelImg标注YOLO格式的数据(案例演示)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain