#-*- coding:utf-8 -*-
import os, glob
import cv2
from scipy.io import loadmat
from collections import defaultdict
import numpy as np
from lxml import etree, objectify
def vbb_anno2dict(vbb_file, cam_id):
#通过os.path.basename获得路径的最后部分“文件名.扩展名”
#通过os.path.splitext获得文件名
filename = os.path.splitext(os.path.basename(vbb_file))[0]
#定义字典对象annos
annos = defaultdict(dict)
vbb = loadmat(vbb_file)
# object info in each frame: id, pos, occlusion, lock, posv
objLists = vbb['A'][0][0][1][0]
objLbl = [str(v[0]) for v in vbb['A'][0][0][4][0]] #可查看所有类别
# person index
person_index_list = np.where(np.array(objLbl) == "person")[0] #只选取类别为‘person’的xml
for frame_id, obj in enumerate(objLists):
if len(obj) > 0:
frame_name = str(cam_id) + "_" + str(filename) + "_" + str(frame_id+1) + ".jpg"
annos[frame_name] = defaultdict(list)
annos[frame_name]["id"] = frame_name
annos[frame_name]["label"] = "person"
for id, pos, occl in zip(obj['id'][0], obj['pos'][0], obj['occl'][0]):
id = int(id[0][0]) - 1 # for matlab start from 1 not 0
if not
将VBB文件转换成XML文件
最新推荐文章于 2022-10-24 18:44:45 发布
![](https://img-home.csdnimg.cn/images/20240711042549.png)