如何批量修改Pascal VOC数据集中xml标签中的标签名称

跑深度学习相关代码的时候,自己标注数据是不可避免的。但有时数据标注完发现学名不符合或者有更合适的标签名来替代,此时一个一个手动修改太麻烦,在此可以通过Python脚本直接批量修改。


  • 代码如下:
import os
import xml.etree.ElementTree as ET

#程序功能:批量修改VOC数据集中xml标签文件的标签名称
def changelabelname(inputpath):
    listdir = os.listdir(inputpath)
    for file in listdir:
        if file.endswith('xml'):
            file = os.path.join(inputpath,file)
            tree = ET.parse(file)
            root = tree.getroot()
            for object1 in root.findall('object'):
                for sku in object1.findall('name'):           #查找需要修改的名称
                    if (sku.text == 'preName'):               #‘preName’为修改前的名称
                        sku.text = 'TESTNAME'                 #‘TESTNAME’为修改后的名称
                        tree.write(file,encoding='utf-8')     #写进原始的xml文件并避免原始xml中文字符乱码
                    else:
                        pass
        else:
            pass

if __name__ == '__main__':
    inputpath = 'E:/Research/Dataset/Test/Annotations'  #此处替换为自己的路径
    changelabelname(inputpath)
YOLOv5 是一个流行的开源目标检测框架,它通常处理的是图像数据,并非XML文件。如果你有包含物体位置信息的XML标注文件,比如PASCAL VOC或者COCO的数据集格式,想要转换成YOLOv5所需的.txt格式,这个过程通常涉及两个步骤: 1. **XML到TXT转换**: - 使用专门的工具或脚本读取XML文件,解析出每个物体的位置、大小和类别标签等信息。 - 每行记录一个目标的坐标(如左上角x, y,宽度,高度),以及类别标签。 - 格式通常是每张图片一行,每一行包含像`class x_center y_center width height`这样的结构。 2. **批量转换**: - 对于批量XML文件,可以编写一个Python脚本通过循环遍历目录下的所有XML文件,对每一个文件执行解析和转换操作。 - 可能需要利用`xml.etree.ElementTree`库来解析XML,或者使用现成的库如`xmltodict`。 以下是一个简单的示例Python脚本片段,用于转换单个XML文件: ```python import xml.etree.ElementTree as ET def convert_xml_to_txt(xml_file): tree = ET.parse(xml_file) root = tree.getroot() with open(xml_file.replace('.xml', '.txt'), 'w') as f: for obj in root.findall('object'): class_name = obj.find('name').text bbox = obj.find('bndbox') x_center = (int(bbox.find('xmin').text) + int(bbox.find('xmax').text)) / 2 y_center = (int(bbox.find('ymin').text) + int(bbox.find('ymax').text)) / 2 width = int(bbox.find('xmax').text) - int(bbox.find('xmin').text) height = int(bbox.find('ymax').text) - int(bbox.find('ymin').text) f.write(f"{class_name} {x_center} {y_center} {width} {height}\n") # 使用方法 convert_xml_to_txt('example.xml') ``` 记得根据实际情况修改路径和脚本细节。对于批量转换,你可以用os模块的list comprehension来处理整个目录下的所有文件。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值