YOLOv9图像标注和格式转换

一、软件安装

labelimg安装(anaconda)

方法一、

pip install labelImg

方法二、

pip install PyQt5 -i https://pypi.tuna.tsinghua.edu.cn/simple/
pip install pyqt5-tools -i https://pypi.tuna.tsinghua.edu.cn/simple/
pip install lxml -i https://pypi.tuna.tsinghua.edu.cn/simple/
pip install labelImg -i https://pypi.tuna.tsinghua.edu.cn/simple/

二、软件标注

打开labelimg环境,运行如下命令即可:

conda activate labelimg
labelimg

 三、格式转换

        标签文件.xml转换为.txt格式

import xml.etree.ElementTree as ET
import os
from os import getcwd

classes = ["pikaqiu",'apple']   # 改成自己的类别
abs_path = os.getcwd()
print(abs_path)

def convert(size, box):
    dw = 1. / (size[0])
    dh = 1. / (size[1])
    x = (box[0] + box[1]) / 2.0 - 1
    y = (box[2] + box[3]) / 2.0 - 1
    w = box[1] - box[0]
    h = box[3] - box[2]
    x = x * dw
    w = w * dw
    y = y * dh
    h = h * dh
    return x, y, w, h

def convert_annotation(xml_id_path,txtpath):
    in_file = open(xml_id_path, encoding='UTF-8')     
    txtpath1=os.path.join(txtpath,xml_id_path.split('\\')[-1].split('.')[0]+'.txt')
    out_file = open(txtpath1, 'w')
    tree = ET.parse(in_file)
    root = tree.getroot()
    size = root.find('size')
    w = int(size.find('width').text)
    h = int(size.find('height').text)
    for obj in root.iter('object'):
        difficult = obj.find('difficult').text
        #difficult = obj.find('Difficult').text
        cls = obj.find('name').text        

        if cls not in classes or int(difficult) == 1:
            continue

        cls_id = classes.index(cls)
        xmlbox = obj.find('bndbox')
        b = (float(xmlbox.find('xmin').text), float(xmlbox.find('xmax').text), float(xmlbox.find('ymin').text),
             float(xmlbox.find('ymax').text))
        b1, b2, b3, b4 = b

        # 标注越界修正
        if b2 > w:
            b2 = w
        if b4 > h:
            b4 = h
        b = (b1, b2, b3, b4)
        bb = convert((w, h), b)
        out_file.write(str(cls_id) + " " + " ".join([str(a) for a in bb]) + '\n')


#xml标签文档地址          
xmlpath=r'C:\Users\admin\xxxxxxxx\labels_xml'
listxmls=os.listdir(xmlpath)
#txt文档保存地址
txtpath=r'C:\Users\admin\xxxxxxxx\labels_txt'
for xml_id in listxmls:
    xml_id_path=os.path.join(xmlpath,xml_id)
    convert_annotation(xml_id_path,txtpath)

四、训练数据参数设置

训练代码链接:项目目录预览 - yolov9 - GitCode

yolov9主目录下的./data路径下重新编写一个.yaml文件

pikaqiu.yaml

train: /media/hadoop/xxxxxxx/VOC/images/train 
val: /media/hadoop/xxxxxxxxx/VOC/images/val
test: /media/hadoop/xxxxxxxx/VOC/images/test
# number of classes
nc: 2
# class names
names: [ 'pikaqiu','apple']

将该文件填入到训练文件train.py中的数据参数设置--data中:


http://www.niftyadmin.cn/n/5395133.html

相关文章

【leetcode每日一题】【滑动窗口长度固定】643.子数组最大平均数

643.子数组最大平均数 长度固定 给你一个由 n 个元素组成的整数数组 nums 和一个整数 k 。 请你找出平均数最大且 长度为 k 的连续子数组,并输出该最大平均数。 示例 1: 输入:nums [1,12,-5,-6,50,3], k 4 输出:12.75 解释&…

Springboot企业级开发--开发入门01

目录 目录 一.Spring Boot的主要特点和优势包括: 二.Spring Boot的核心功能可以归纳为以下几点: 三.Springboot是如何解决问题? Spring Boot 是一个开源的Java框架,其设计目标是为了简化新Spring应用的初始搭建以及开发过程。…

java找工作之多线程

多线程 线程:java.Thread 线程简介 想要了解多线程首先就要了解什么是单线程,单线程运行程序时,如果调用了其他方法,会将其他方法加入到当前的线程中,只有主线程一条执行路径,而多线程运行程序时会有多条…

信钰证券:股票k线图中b和s是什么情况?一文带你了解!

股票K线图是投资者在研讨股票时经常会用到的一种图表,用来展现股票的价格走势。那么股票k线图中b和s是什么状况?下面就由信钰证券为我们剖析: 股票k线图中b和s是什么状况: 股票K线图中B代表Buy,也便是买入的意思&…

MySQL Explain使用教程

1.Explain含义 Explain是 SQL 分析工具中非常重要的一个功能,它可以模拟优化器执行查询语句,帮助我们理解查询是如何执行的;分析查询执行计划可以帮助我们发现查询瓶颈,优化查询性能。 2.Explain作用 表的读取顺序SQL执行时查询…

数据安全策略

当您在第一线担负着确保公司的信息和系统尽可能免受风险的关键职责时,您的数据安全策略需要复杂且多层次。威胁可能有多种形式:恶意软件、黑客攻击、财务或信息盗窃、破坏、间谍活动,甚至是您信任的员工故意或无意的活动造成的。因此&#xf…

vue + koa + 阿里云部署 + 宝塔:宝塔前后端部署

接上篇,我们已经完成了宝塔的基本配置,下面我们来看如何在宝塔中部署前后端 一、上传前后端代码文件 在www > wwwroot目录下创建了一个demo文件,用来存放前后端代码 进入demo中,点击上传 这里前端我用的打完包的 dist文件&am…

【Spring连载】使用Spring Data的Repositories----核心概念Core concepts

【Spring连载】使用Spring Data的Repositories----核心概念Core concepts 实体状态检测策略 Spring Data存储库抽象中的中心接口是Repository。它使用要管理的域类以及域类的标识符类型作为类型参数。此接口主要充当标记接口,用于捕获要使用的类型,并帮助…