首页 > 编程语言 >深入解析:如何通过Python脚本将YOLO标注格式转换为COCO格式并进行验证

深入解析:如何通过Python脚本将YOLO标注格式转换为COCO格式并进行验证

时间:2024-06-18 09:29:20浏览次数:34  
标签:Python YOLO COCO 格式 os dir 标注

深入解析:如何通过Python脚本将YOLO标注格式转换为COCO格式并进行验证

随着深度学习和计算机视觉技术的飞速发展,物体检测成为了一个热门的研究领域。在物体检测任务中,YOLO(You Only Look Once)和COCO(Common Objects in Context)是两个非常重要的标注格式。YOLO因其高效的实时物体检测能力受到广泛关注,而COCO则是一个包含大量标注数据集的标准化格式,广泛应用于学术研究和工业实践。然而,许多研究人员和开发者在处理不同格式的数据集时常常面临着转换标注格式的挑战。本文将详细介绍如何通过Python脚本将YOLO标注格式转换为COCO格式,并通过图像可视化对转换结果进行验证。

YOLO和COCO标注格式简介

在开始具体的代码实现之前,我们先了解一下YOLO和COCO标注格式的基本概念。

YOLO标注格式

YOLO标注格式是一种简单而高效的标注方式,每个标注文件对应一张图像,文件中每一行代表一个物体的检测框。每行的数据包括:

  1. 类别(class)
  2. 中心点x坐标(x_center)
  3. 中心点y坐标(y_center)
  4. 检测框宽度(bbox_width)
  5. 检测框高度(bbox_height)

所有坐标和尺寸都是相对于图像宽度和高度的比例值,范围在0到1之间。例如,一个标注文件内容如下:

0 0.5 0.5 0.2 0.3
1 0.3 0.6 0.1 0.2

在上述例子中,第一行代表类别为0的物体,其中心点位于图像的正中心,宽度为图像宽度的20%,高度为图像高度的30%。第二行代表类别为1的物体,其中心点位于图像宽度的30%处,高度的60%处,宽度为图像宽度的10%,高度为图像高度的20%。

COCO标注格式

COCO标注格式则更加复杂,它使用JSON文件存储标注数据。COCO格式包括多个字段,其中最主要的字段有:

  1. images:包含图像的元数据,如文件名、高度、宽度和图像ID。
  2. annotations:包含物体检测框的详细信息,如图像ID、类别ID、检测框坐标(xmin, ymin, width, height)、区域面积和是否为密集对象。
  3. categories:包含类别的ID和名称。

一个COCO标注文件的示例如下:

{
   
  "images": [
    {
   
      "file_name": "000000000001.jpg",
      "height": 800,
      "width": 600,
      "id": 1
    }
  ],
  "annotations": [
    {
   
      "id": 1,
      "image_id": 1,
      "category_id": 1,
      "bbox": [100, 200, 50, 50],
      "area": 2500,
      "iscrowd": 0
    }
  ],
  "categories": [
    {
   
      "id": 1,
      "name": "person"
    }
  ]
}

在上述例子中,images字段描述了一张图像的信息,annotations字段描述了该图像中的一个标注,categories字段描述了类别的信息。每个字段都有详细的子字段,以确保标注信息的全面性和准确性。

将YOLO标注格式转换为COCO标注格式

接下来,我们将介绍如何通过Python脚本将YOLO标注格式转换为COCO标注格式。我们会逐步解释脚本中的关键部分,并添加必要的异常处理,以确保代码的鲁棒性和容错性。

导入必要的库

首先,我们需要导入一些必要的库,包括jsonosPIL(用于图像处理)和matplotlib(用于图像可视化)。

import json
import os
from PIL import Image
import matplotlib.pyplot as plt
import matplotlib.patches as patches

定义转换函数

接下来,我们定义一个函数convert_yolo_to_coco,用于将YOLO标注格式转换为COCO标注格式。

def convert_yolo_to_coco(dataset_dir):
    subsets = ['train2017', 'val2017']
    annotations_dir = os.path.join(dataset_dir, 'annotations')

    if not os.path.exists(annotations_dir):
        os.makedirs(annotations_dir)

    for subset in subsets:
        image_dir = os.path.join(dataset_dir, 'images', subset)
        label_dir = os.path.join(dataset_dir, 'labels', subset)
        images = []
        annotations = []

        image_id = 1
        annotation_id = 1

        for filename in os.listdir(image_dir):
            if filename.endswith('.jpg'):
                image_path = os.path.join(image_dir, filename)
                label_path = os.path.join(label_dir, filename.replace('.jpg', '.txt'))
                
                try:
                    with Image.open(image_path) as img:
                        width, height = img.size
                
                    images.append({
   
                        'file_name': filename,
                        'height': height,
                        'width': width,
                        'id': image_id
                    })
                    
   

标签:Python,YOLO,COCO,格式,os,dir,标注
From: https://blog.csdn.net/m0_57781768/article/details/139740478

相关文章

  • 深入解析:如何通过Python脚本将LabelMe标注格式转换为YOLO格式并进行验证
    深入解析:如何通过Python脚本将LabelMe标注格式转换为YOLO格式并进行验证在计算机视觉领域,标注格式的转换是一个经常会遇到的问题。不同的标注格式有不同的应用场景和优势,能够灵活地进行转换是非常重要的技能。在这篇文章中,我们将详细介绍如何通过Python脚本将LabelMe标注格......
  • 【python】OpenCV—Segmentation
    文章目录cv2.kmeans牛刀小试cv2.kmeanscv2.kmeans是OpenCV库中用于执行K-Means聚类算法的函数。以下是根据参考文章整理的cv2.kmeans函数的中文文档:一、函数功能cv2.kmeans用于执行K-Means聚类算法,将一组数据点划分到K个簇中,使得簇内的数据点尽可能相......
  • 17.零代码八爪鱼采集器数据采集与数据导出——如何导出不同格式数据和数据推送到数据
    首先,多数情况下免费版本的功能,已经可以满足绝大多数采集需求,想了解八爪鱼采集器版本区别的详情,请访问这篇帖子: 3.无代码爬虫八爪鱼采集器工具介绍——个人版本、团队版本的适用性_八爪鱼采集器有单机版本吗-CSDN博客免费版八爪鱼采集器下载​​https://affiliate.bazhuayu.c......
  • 使用Python获取HTTP请求头数据
    前言在Web开发和API交互中,HTTP请求头扮演着至关重要的角色。它们不仅告诉服务器请求的类型(如GET、POST等),还包含了关于客户端、请求内容以及其他重要信息的数据。在Python中,我们可以使用requests库来发送HTTP请求,并查看服务器返回的响应头,但通常我们也需要了解我们发送的请求头内......
  • Python - class Method and static Method
    Themethodsinaclassareassociatedwiththeobjectscreatedforit.Forinvokingthemethodsdefinedinsidethemethod,thepresenceofaninstanceisnecessary.Theclassmethodisamethodthatisalsodefinedinsidetheclassbutdoesnotneedanyob......
  • 精准控制:Python 输入数值范围限制详解
    前言在实际开发过程中,经常需要对用户输入的数值进行限制,以确保输入的数据在合理的范围内。这不仅能防止程序错误,还能提高用户体验。作为一名测试工程师,掌握如何在Python中限制输入数值范围是非常有用的技能。本文将详细介绍如何使用Python实现这一功能,包括基础方法和高级应用......
  • Python - Overloading
    ObjectOrientedProgramming(OOP)allowstheprogrammerstoaddsomeadditionalfunctionalitiestotheoperatorsandmethodswhichhavebasicproperties.Suchakindofredefiningoftheentitiesoftheprogrammingstructureiscalledaspolymorphism.In......
  • yolov8从零开始到训练自己的数据集,保姆式教学文档,适合初学者
     1.搭配yolov8环境1.1 下载Conda并且搭配虚拟环境1.1.1Conda的作用    Conda是一个开源的软件包管理系统和环境管理系统,主要用于安装多个版本的软件包及其依赖关系,并能在不同环境间轻松切换。其作用在于为开发者提供一个统一的平台来管理项目的依赖关系和环境,确......
  • Python函数式编程
    函数式编程基础函数式编程与面向对象编程一样都是一种编程范式,函数式编程也称为面向函数的编程。Python提供了高阶函数、函数类型和lambda表达式,他们是实现函数式编程的基础。高阶函数与函数类型如果一个函数可以作为其他函数的参数或者其他函数的返回值,那么这个函数就是“......
  • 目标检测算法之YOLO(YOLOv4-YOLOv6)
    YOLO算法理解YOLOv4BagofspecialsCross-stagepartialconnections(CSP)SpatialPyramidPooling(SPP)PANpath-aggregationblockSAMMishactivationMulti-inputweightedresidualconnections(MiWRC)BagoffreebiesMosaic方法ClasslabelsmoothCmBN和Dynamicmini-ba......