统计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)


相关推荐

  • 怎样在python上安装jieba库_无法安装lxml库

    怎样在python上安装jieba库_无法安装lxml库jieba库是python的一个三方扩展库,想要使用就需要大家下载和安装之后才可以,但有不少同学不知道该如何操作。今天小千就来给大家介绍如何安装jieba库。安装jieba库步骤在安装之前同学们一定要正确安装python运行环境,这一步就不介绍了。1.之后我们打开CMD命令提示,按下win+r,在里面输入CDM即可。2.随后我们在打开的窗口中直接输入命令:pipinstalljieba,然后按下回车之后就会自动开始下载安装,我们只需要等待一会即可。3.安装完成之后,如果不确定是否正确安装,

  • win10关闭端口占用[通俗易懂]

    win10关闭端口占用[通俗易懂]查看win10所有占用端口公式:查看所有:netstat-ano查看对应端口:netstat-ano|findstr"9004"关闭端口:任务管理器中的详细信息对应的PID就是占用的端口关闭即可命令行关闭端口:taskkill-PID进程号-F进程号为19216…

  • ping 与 traceroute 的工作原理分析

    ping 与 traceroute 的工作原理分析一、ping    ping程序的主要目的是测试主机是否可达,它发送 ICMP回显请求报文给目的主机,并等待返回ICMP回显应答    ping程序一般会周期性持续地发送ICMP请求报文,除非用户手动终止,或指定了发送报文个数    回显请求和回显应答通过序列号(icmp_seq)进行匹配,下图中序列号依次为1、2、3、4…    pi…

  • centos7 top命令_linux系统top命令

    centos7 top命令_linux系统top命令top命令Linuxtop命令用于实时显示process的动态。top参数详解第一行,任务队列信息**系统当前时间:**13:52:56**系统开机后到现在的总运行时间:**up66

  • go lang的激活码2021(最新序列号破解)

    go lang的激活码2021(最新序列号破解),https://javaforall.cn/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

  • java StringTokenizer_string s=new string[10]

    java StringTokenizer_string s=new string[10]StringTokenizer类:解析字符串单词和split方法不同的是,StringTokenizer对象不使用正则表达式做分隔标记有时候要分析字符串并将字符串分解成可独立使用的单词,这些单词称为语言符号。对于字符串“Iamstudent”,如果把空格作为该字符串的标记,那么该字符串有三个单词(语言符号)。对于字符串“I,am,student”,如果把逗号作为该字符串的标…

发表回复

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

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