在yolov5中,如何将xml格式转换为yolov5所需的txt格式(超详细)

这是一堆xml文件,但是在yolov5中需要的是txt文件,现在需要的是将xml转换为txt文件。
在这里插入图片描述
先看一下xml文件的内容
在这里插入图片描述
下面是转换的全部代码,只要安装python就可以直接运行。

import xml.etree.ElementTree as ET
 
import pickle
import os
from os import listdir , getcwd
from os.path import join
import glob
 
classes = ["ship"]
 
def convert(size, box):
 
    dw = 1.0/size[0]
    dh = 1.0/size[1]
    x = (box[0]+box[1])/2.0
    y = (box[2]+box[3])/2.0
    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(image_name):
    in_file = open('./Annotations_new/'+image_name[:-3]+'xml') #xml文件路径
    out_file = open('./lables/'+image_name[:-3]+'txt', 'w') #转换后的txt文件存放路径
    f = open('./Annotations_new/'+image_name[:-3]+'xml')
    xml_text = f.read()
    root = ET.fromstring(xml_text)
    f.close()
    size = root.find('size')
    w = int(size.find('width').text)
    h = int(size.find('height').text)
 
 
 
 
    for obj in root.iter('object'):
        cls = obj.find('name').text
        if cls not in classes:
            print(cls)
            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))
        bb = convert((w,h), b)
        out_file.write(str(cls_id) + " " + " ".join([str(a) for a in bb]) + '\n')
 
wd = getcwd()
 
if __name__ == '__main__':
 
    for image_path in glob.glob("./JPEGImages/*.jpg"): #每一张图片都对应一个xml文件这里写xml对应的图片的路径
        image_name = image_path.split('\\')[-1]
        convert_annotation(image_name)

这是我的目录结构
在这里插入图片描述
1.py里面存放的是上面的代码,在给我你的代码里面,你只需要改动四个地方即可(就是改图片的路径,xml文件的路径,和最终转换的txt文件的存储路径),这个路径大家要是改不好的话,就写绝对路径,这样就不会报错了。
在这里插入图片描述
在这里插入图片描述
最终生成的文件
在这里插入图片描述
打开一个文件看看
在这里插入图片描述
大功告成!

修改记录:2023/12/24
不知道为什么这段代码在ubuntu里面一直报下面这个错误
在这里插入图片描述
我在windows却没有问题。

  • 24
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
您可以使用以下步骤将XML文件换为Yolov5txt格式: 1. 首先,要安装并配置好Python环境。 2. 使用Python的xml.etree.ElementTree库来解析XML文件。您可以使用以下代码示例: ```python import xml.etree.ElementTree as ET def parse_xml(xml_path): tree = ET.parse(xml_path) root = tree.getroot() annotations = [] for obj in root.findall('object'): name = obj.find('name').text xmin = int(obj.find('bndbox/xmin').text) ymin = int(obj.find('bndbox/ymin').text) xmax = int(obj.find('bndbox/xmax').text) ymax = int(obj.find('bndbox/ymax').text) annotations.append((name, xmin, ymin, xmax, ymax)) return annotations ``` 此函数将返回一个包含每个对象的名称和边界框坐标的列表。 3. 使用上面定义的函数解析XML文件,并将结果保存到一个列表。假设您有一个名为`annotations`的列表。 ```python annotations = parse_xml('path/to/your/xml/file.xml') ``` 4. 将对象的名称和边界框坐标写入Yolov5txt文件。每个对象的标签应该以以下格式写入: ``` <class_label> <x_center> <y_center> <width> <height> ``` 其,`<class_label>`是对象的类别标签,`<x_center>`和`<y_center>`是边界框心点的相对坐标(相对于图像的宽度和高度),`<width>`和`<height>`是边界框的宽度和高度的相对值(相对于图像的宽度和高度)。 以下是将结果写入txt文件的示例代码: ```python def write_txt(annotations, txt_path): with open(txt_path, 'w') as f: for annotation in annotations: class_label, xmin, ymin, xmax, ymax = annotation x_center = (xmin + xmax) / 2 y_center = (ymin + ymax) / 2 width = xmax - xmin height = ymax - ymin f.write(f"{class_label} {x_center} {y_center} {width} {height}\n") ``` 使用上面定义的函数将结果写入txt文件: ```python write_txt(annotations, 'path/to/your/txt/file.txt') ``` 将`'path/to/your/xml/file.xml'`替换为您的XML文件路径,将`'path/to/your/txt/file.txt'`替换为您想要保存txt文件的路径。 完成以上步骤后,您将获得一个包含对象标签的Yolov5格式txt文件。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我要变胖哇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值