1. 程式人生 > 其它 >根據xml檔案中目標座標計算目標占比、長寬、面積等

根據xml檔案中目標座標計算目標占比、長寬、面積等

技術標籤:好用的python小程式python

在這裡插入圖片描述
下面程式主要用來統計:

計算每一個目標在原圖中的佔比;
計算目標的平均長度;
計算平均寬度;
計算平均面積;
計算目標平均佔比;

# -*- coding:utf-8 -*-
import os
import xml.etree.ElementTree as ET
import numpy as np

#np.set_printoptions(suppress=True, threshold=np.nan)  #10,000,000
np.set_printoptions(suppress=True, threshold=10000000)  #10,000,000
import
matplotlib from PIL import Image def parse_obj(xml_path, filename): tree = ET.parse(xml_path + filename) objects = [] for obj in tree.findall('object'): obj_struct = {} obj_struct['name'] = obj.find('name').text bbox = obj.find('bndbox') obj_struct['bbox'
] = [int(bbox.find('xmin').text), int(bbox.find('ymin').text), int(bbox.find('xmax').text), int(bbox.find('ymax').text)] objects.append(obj_struct) return objects def read_image(image_path, filename)
: im = Image.open(image_path + filename) W = im.size[0] H = im.size[1] area = W * H im_info = [W, H, area] return im_info if __name__ == '__main__': image_path = '/VOCdevkit/VOC2007/JPEGImages/' xml_path = '/VOCdevkit/VOC2007/Annotations/' filenamess = os.listdir(xml_path) filenames = [] for name in filenamess: name = name.replace('.xml', '') filenames.append(name) print(filenames) recs = {} ims_info = {} obs_shape = {} classnames = [] num_objs={} obj_avg = {} for i, name in enumerate(filenames): print('正在處理 {}.xml '.format(name)) recs[name] = parse_obj(xml_path, name + '.xml') print('正在處理 {}.jpg '.format(name)) ims_info[name] = read_image(image_path, name + '.jpg') print('所有資訊收集完畢。') print('正在處理資訊......') for name in filenames: im_w = ims_info[name][0] im_h = ims_info[name][1] im_area = ims_info[name][2] for object in recs[name]: if object['name'] not in num_objs.keys(): num_objs[object['name']] = 1 else: num_objs[object['name']] += 1 #num_objs += 1 ob_w = object['bbox'][2] - object['bbox'][0] ob_h = object['bbox'][3] - object['bbox'][1] ob_area = ob_w * ob_h w_rate = ob_w / im_w h_rate = ob_h / im_h area_rate = ob_area / im_area if not object['name'] in obs_shape.keys(): obs_shape[object['name']] = ([[ob_w, ob_h, ob_area, w_rate, h_rate, area_rate]]) else: obs_shape[object['name']].append([ob_w, ob_h, ob_area, w_rate, h_rate, area_rate]) if object['name'] not in classnames: classnames.append(object['name']) # 求平均 for name in classnames: obj_avg[name] = (np.array(obs_shape[name]).sum(axis=0)) / num_objs[name] print('{}的情況如下:*******\n'.format(name)) print(' 目標平均W={}'.format(obj_avg[name][0])) print(' 目標平均H={}'.format(obj_avg[name][1])) print(' 目標平均area={}'.format(obj_avg[name][2])) print(' 目標平均與原圖的W比例={}'.format(obj_avg[name][3])) print(' 目標平均與原圖的H比例={}'.format(obj_avg[name][4])) print(' 目標平均原圖面積佔比={}\n'.format(obj_avg[name][5])) print('資訊統計計算完畢。')