代码拉取完成,页面将自动刷新
#!/usr/bin/env python
import os
import Image
import sys
import zipfile
import xml.etree.ElementTree as ET
import argparse
def scanAnnotationFolder(annotationFolderPath):
annotationFiles = []
for root, dirs, files in os.walk(annotationFolderPath):
for file in files:
if file.endswith('.xml'):
annotationFiles.append(os.path.join(root, file))
return annotationFiles
# Bounding Box Helper
class BBoxHelper:
def __init__(self, annotation_file, image_path=None):
self.annotation_file = annotation_file
xmltree = ET.parse(annotation_file)
filename = xmltree.find('filename').text
wnid = filename.split('_')[0]
image_id = filename.split('_')[1]
# create a dict to save filename, wnid, image id, etc..
self.annotation_filename = filename
self.wnid = wnid
self.image_id = image_id
# find bounding box
objects = xmltree.findall('object')
self.rects = []
for object_iter in objects:
bndbox = object_iter.find("bndbox")
self.rects.append([int(it.text) for it in bndbox])
localPath = xmltree.find('path')
self.imgPath = None
if localPath is not None and os.path.exists(localPath.text):
self.imgPath = localPath.text
if image_path is not None:
self.imgPath = image_path
def saveBoundBoxImage(self, imgPath=None, outputFolder=None):
if imgPath is not None:
self.imgPath = imgPath
if imgPath is None and self.imgPath is None:
self.imgPath = self.findImagePath()
if outputFolder == None:
outputFolder = os.path.join(self.wnid, 'bounding_box_imgs')
# annotation_file_dir = os.path.dirname(os.path.realpath(self.annotation_file))
# outputFolder = os.path.join(annotation_file_dir, savedTargetDir)
if not os.path.exists(outputFolder):
os.mkdir(outputFolder)
# Get crop images
bbs = []
im = Image.open(self.imgPath)
for box in self.rects:
bbs.append(im.crop(box))
# Save them to target dir
count = 0
for box in bbs:
count = count + 1
outPath = str(os.path.join(outputFolder, self.annotation_filename + '_box' + str(count) + '.JPEG'))
box.save(outPath)
print 'save to ' + outPath
def get_BoudingBoxs(self):
return self.rects
def getWnid(self):
return self.wnid
def findImagePath(self, search_folder='.'):
filename = self.annotation_filename + str('.JPEG')
for root, dirs, files in os.walk(search_folder):
for file in files:
if filename == file:
return os.path.join(root, file)
print filename + ' not found'
return None
def saveAsBoudingBoxImg(xmlfile):
bbhelper = BBoxHelper(xmlfile)
print bbhelper.findImagePath()
# Search image path according to bounding box xml, and crop it
if shouldSaveBoundingBoxImg:
print bbhelper.get_BoudingBoxs()
bbhelper.saveBoundBoxImage()
if __name__ == '__main__':
p = argparse.ArgumentParser(description='Help the user to download, crop, and handle images from ImageNet')
p.add_argument('--bxmlpath', help='Boudingbox xml path')
p.add_argument('--bxmldir', help='Boudingbox dir path')
p.add_argument('--save_boundingbox', help='Search images and crop the bounding box by image paths', action='store_true', default=False)
args = p.parse_args()
# Give bounding_box XML and show its JPEG path and bounding rects
boundingbox_xml_file = args.bxmlpath
boudingbox_xml_dir = args.bxmldir
shouldSaveBoundingBoxImg = args.save_boundingbox
if not boundingbox_xml_file is None:
saveAsBoudingBoxImg(boundingbox_xml_file)
if not boudingbox_xml_dir is None:
allAnnotationFiles = scanAnnotationFolder(boudingbox_xml_dir)
for xmlfile in allAnnotationFiles:
saveAsBoudingBoxImg(xmlfile)
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。