统计xml文件中标记框的特性

统计xml文件中标记框的特性

统计xml文件中标记框的特性

使用labelimg对图片进行标记之后保存为xml文件,运行脚本统计xml文件中的标记框的特征。

代码如下:

 import os
    import sys
    filedir = os.path.dirname(sys.argv[0])      #获取脚本所在目录
    os.chdir(filedir)       #将脚本所在的目录设置为工作目录
    wdir = os.getcwd()
    print('当前工作目录:{}\n'.format(wdir))      #打印当前工作目录
    
    from xml.dom.minidom import parse
    
    def xml_parser( xml_file ):
        '''
        Parse an xml file and return the annotation info in the file
    
        :param xml_file: the xml file name to be parsed
        :return: file_name, width, height, objects.
            file_name, filename of the xml file (without extension)
            width, width of the annotated image
            height, height of the annotated image
            objects, annotated objects in the image
            object, (object_name, xmin, ymin, xmax, ymax)
                object_name, name of the annotated object
                xmin, ymin, xmax, ymax, coordinate of the bounding box of the object
    
        '''
        DOMTree = parse( xml_file )
        collection = DOMTree.documentElement #得到xml文件的根节点
        file_name_xml = collection.getElementsByTagName( 'filename' )[0]
        objects_xml = collection.getElementsByTagName( 'object' )
        size_xml = collection.getElementsByTagName( 'size' )
    
        file_name = file_name_xml.childNodes[0].data
    
        for size in size_xml:
            width = size.getElementsByTagName( 'width' )[0]
            height = size.getElementsByTagName( 'height' )[0]
    
            width = width.childNodes[0].data
            height = height.childNodes[0].data
    
        objects = []
        for object_xml in objects_xml:
            object_name = object_xml.getElementsByTagName( 'name' )[0]
            bdbox = object_xml.getElementsByTagName( 'bndbox' )[0]
            xmin = bdbox.getElementsByTagName( 'xmin' )[0]
            ymin = bdbox.getElementsByTagName( 'ymin' )[0]
            xmax = bdbox.getElementsByTagName( 'xmax' )[0]
            ymax = bdbox.getElementsByTagName( 'ymax' )[0]
    
            object = [ object_name.childNodes[0].data,
                       float(xmin.childNodes[0].data),
                       float(ymin.childNodes[0].data),
                       float(xmax.childNodes[0].data),
                       float(ymax.childNodes[0].data) ]
    
            objects.append( object )
    
        return file_name, int(width), int(height), objects
        
    image_dir = 'images'    
    xml_dir = 'labels'
    xml_files = os.listdir(xml_dir)
    image_files = os.listdir(image_dir)
    image_ext = image_files[0].split('.')[-1] #图片文件的扩展名
    print(image_ext)
    if len(image_files) == len(xml_files):
        print('共有{:d}个xml文件。'.format(len(xml_files)))
    else:
        print('图片数量和xml文件数量不一致。')
    obj_dict = {}
    for xml_file in xml_files:
        annotation = xml_parser(os.path.join(xml_dir, xml_file))
        name_1 = xml_file.split('.')[0] + '.' + image_ext.lower()
        name_2 = xml_file.split('.')[0] + '.' + image_ext.upper()
        if  name_1 not in image_files and name_2 not in image_files:
            print('{:s}没有对应的图片。'.format(xml_file))
        for obj in annotation[-1]:
            key = obj[0]
            x = (obj[1] + obj[3])/2
            y = (obj[2] + obj[4])/2
            width = obj[3] - obj[1]
            height = obj[4] - obj[2]
            box = [x,y,width,height]
            if key in obj_dict:
                obj_dict[key][0] += 1
                n = obj_dict[key][0]
                obj_dict[key][1:5] = [ (i*(n-1)+j)/(n) for i,j in zip(obj_dict[key][1:5] , box)]
                #obj_dict[key][5:9] = [ i if i>=j else j for i,j in zip(obj_dict[key][5:9] , box)]
                #obj_dict[key][9:] = [ i if i>=j else j for i,j in zip(obj_dict[key][9:] , box)]
            else:
                obj_dict[key] = []
                obj_dict[key].append(1)  # 0,个数
                obj_dict[key] += box     # 1-4, 平均坐标
                #obj_dict[key] += box     # 5-8, 最大值
                #obj_dict[key] += box     # 9-12,最小值
    for key,value in obj_dict.items():
        print('一共有 {:4d} 个 {:20s},其边框平均位置为{:4.0f} *{:4.0f};平均尺寸为{:3.0f} *{:3.0f}。'.format(value[0],key,*value[1:]))
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/2173.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • amos路径分析结果怎么看_路径分析图怎么解读

    amos路径分析结果怎么看_路径分析图怎么解读基础准备草堂君在前面几篇文章中,介绍了AMOS软件的操作、分析原理、结构方程模型和各种拟合指标含义等内容,大家可以点击下面的文章链接回顾,也可以从公众号导航栏获取AMOS分析技术(导航页)回顾:AMOS分析技术:软件安装及菜单功能介绍;这次是视频教程AMOS分析技术:结构方程模型的拟合度评价指标AMOS分析技术:模型整体拟合度指标AMOS分析

  • kit中文_flask和django的对比

    kit中文_flask和django的对比#介绍ImageKit是用于处理图像的Django应用程序。如果需要从原图上生成一个长宽为50×50的图像,则需要ImageKit。ImageKit附带了一系列图像处理器,用于调整大小和裁剪等常见

  • idea 2021激活码【永久激活】

    (idea 2021激活码)最近有小伙伴私信我,问我这边有没有免费的intellijIdea的激活码,然后我将全栈君台教程分享给他了。激活成功之后他一直表示感谢,哈哈~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.htmlWK…

  • fiddler抓包模拟器教程_wpe手机模拟器抓包

    fiddler抓包模拟器教程_wpe手机模拟器抓包1.打开,Fiddler.点击tools设置,把HPPPS证书保存在桌面,拖动到安卓模拟器里面.重启Fiddler2.长按网络,修改主机名和端口.在设置[安全]里,添加证书.转载于:https://www.cnblogs.com/limi2019/articles/11411904.html…

  • 用C语言实现PID控制代码[通俗易懂]

    用C语言实现PID控制代码[通俗易懂]PID控制算法的C语言实现一PID算法原理  最近两天在考虑一般控制算法的C语言实现问题,发现网络上尚没有一套完整的比较体系的讲解。于是总结了几天,整理一套思路分享给大家。  在工业应用中PID及其衍生算法是应用最广泛的算法之一,是当之无愧的万能算法,如果能够熟练掌握PID算法的设计与实现过程,对于一般的研发人员来讲,应该是足够应对一般研发问题了,而难能可贵的是,在我所接触的控制算法当中,P…

  • 苹果电脑出现 .DS_Store文件,删除不掉怎么处理?

    苹果电脑出现 .DS_Store文件,删除不掉怎么处理?

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号