根据指定标签的xml文件选出对应标签的图片
# coding=utf-8"""选出指定标签的xml文件"""# """选出对应标签的图片"""import osimport os.pathimport xml.dom.minidomimport shutilimport syspath = "F:/aiuc/在批量xml标签中选出指定标签和对应图片/workcloth_person/3"newpath = "\\new\\label"# l
·
import numpy as np
import glob
import os
import xml.etree.ElementTree as ET
import xml.dom.minidom
'''
第一步,将xml文件和图片重新命名
'''
# 获取文件夹中bmp图片的数量
def getDirImageNum(path):
bmpDirImagesNum = 0
for bmpfile in os.listdir(path):
if os.path.splitext(bmpfile)[1] == '.jpeg':
bmpDirImagesNum += 1
return bmpDirImagesNum
# 获取文件夹中xml文件的数量
def getDirXmlNum(path):
xmlDirXmlNum = 0
for xmlfile in os.listdir(path):
if os.path.splitext(xmlfile)[1] == '.xml':
xmlDirXmlNum += 1
return xmlDirXmlNum
inputpath1 = "./n02971356/"
inputpath2 = './n02971356-xml/'
outpath1 = "./1"
outpath2 = './2'
file_name = os.listdir(inputpath2)
flag=1
error = []
for item in file_name:
print(item)
o_imap = inputpath1 + item.split('.')[0] + ".jpeg"
o_xmlp = inputpath2 + item.split('.')[0] + ".xml"
print(o_imap)
print(o_xmlp)
i = getDirImageNum(outpath1) # 表示bmp文件的命名是从当前输出文件夹中的bmp文件数目开始的
print(i)
if os.path.exists(o_imap) and os.path.exists(o_xmlp):
print('dhsaudusadugasgdgha')
i = i + 1
print(i)
new_name = '4' + format(str(i), '0>5s') + '.jpeg'
dst1 = os.path.join(os.path.abspath(outpath1), new_name) # 为000001.jpg
os.rename(o_imap, dst1)
dst2 = os.path.join(os.path.abspath(outpath2), '4' + format(str(i), '0>5s') + '.xml') # 为000000.xml形式,想要的格式
try:
dom = xml.dom.minidom.parse(o_xmlp)
root = dom.documentElement
# 获取标签对path之间的值并赋予新值j
# 文件夹赋值
root.getElementsByTagName('folder')[0].firstChild.data = "VOC2007"
# 获取标签对filename之间的值并赋予新值j
root.getElementsByTagName('filename')[0].firstChild.data = new_name
# 将修改后的xml文件保存,xml文件修改前后的路径
# 打开并写入
with open(o_xmlp, 'w') as fh:
dom.writexml(fh)
os.rename(o_xmlp, dst2)
print('converting %s to %s ...' % (o_xmlp, dst2))
except:
error.append(new_name)
continue
# 如果有出错的文件,error++
print(len(error))
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐


所有评论(0)