前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >VOC格式转CSV

VOC格式转CSV

作者头像
狼啸风云
修改2022-09-02 19:46:52
1.1K0
修改2022-09-02 19:46:52
举报
文章被收录于专栏:计算机视觉理论及其实现
代码语言:javascript
复制
import os
import xml.dom.minidom
 
 
path_img = "VOC2007/JPEGImages"
path_xml = "VOC2007/Annotations"
 
xml_list = []
for xml1 in os.listdir(path_xml):
    if xml1.endswith(".xml"):
        xml_list.append(xml1)
 
csv_labels = open("csv_labels.csv", "w")
for xml_file in xml_list:
    image_id, _ = os.path.splitext(xml_file)
 
    DomTree = xml.dom.minidom.parse(os.path.join(path_xml, xml_file))
    annotation = DomTree.documentElement
    objectlist = annotation.getElementsByTagName('object')
    for objects in objectlist:
        namelist = objects.getElementsByTagName('name')
        objectname = namelist[0].childNodes[0].data
        bndbox = objects.getElementsByTagName("bndbox")
        for box in bndbox:
            x1_list = box.getElementsByTagName('xmin')
            x1 = int(x1_list[0].childNodes[0].data)
            y1_list = box.getElementsByTagName('ymin')
            y1 = int(y1_list[0].childNodes[0].data)
            x2_list = box.getElementsByTagName('xmax')
            x2 = int(x2_list[0].childNodes[0].data)
            y2_list = box.getElementsByTagName('ymax')
            y2 = int(y2_list[0].childNodes[0].data)
        line = str(image_id) + "," + str(x1) + "," + str(y1) \
               + "," + str(x2) + "," + str(y2) + "," + objectname + "\n"
        print(line)
        csv_labels.write(line)
csv_labels.close()
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/01/08 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档