需求: ? ? ? ? 數(shù)據(jù)集的數(shù)據(jù)增強中,有時需要用到圖像垂直翻轉的操作,圖像垂直翻轉后,對應的xml標注文件也需要做坐標的調(diào)整。 ? 解決方法: ? ? ? ? 使用python+opencv+import xml.etree.ElementTree對圖像垂直翻轉和xml標注文件坐標調(diào)整。代碼如下:
import cv2
import os
import glob
import xml.etree.ElementTree as et
def flip_images(source_dir):
images_list = glob.glob(os.path.join(source_dir, "*.jpg"))
index = 0
for image_path in images_list:
image = cv2.imread(image_path)
flip_image = cv2.flip(image,0)
cv2.imwrite(image_path.replace(".jpg", "_flip.jpg"), flip_image)
tree_ = et.ElementTree()
tree_.parse(image_path.replace(".jpg", ".xml"))
root = et.Element("annotation")
folder = et.SubElement(root, "folder")
folder.text = "images"
filename = et.SubElement(root, "filename")
filename.text = tree_.find(".//filename").text.replace(".jpg", "_flip.jpg")
path = et.SubElement(root, "path")
path.text = "/home/mapgoo/test"
source = et.SubElement(root, "source")
database = et.SubElement(source, "database")
database.text = "Unknown"
size = et.SubElement(root, "size")
width = et.SubElement(size, "width")
width.text = tree_.find(".//width").text
height = et.SubElement(size, "height")
height.text = tree_.find(".//height").text
depth = et.SubElement(size, "depth")
depth.text = "3"
segmented = et.SubElement(root, "segmented")
segmented.text = "0"
for bndbox in tree_.findall(".//object"):
xmin = bndbox.find(".//xmin")
ymin = bndbox.find(".//ymin")
xmax = bndbox.find(".//xmax")
ymax = bndbox.find(".//ymax")
xmin_text = xmin.text
ymin_text = ymin.text
xmax_text = xmax.text
ymax_text = ymax.text
object_ = et.SubElement(root, "object")
name = et.SubElement(object_, "name")
name.text = bndbox.find("name").text
pose = et.SubElement(object_, "pose")
pose.text = "Unspecified"
truncated = et.SubElement(object_, "truncated")
truncated.text = "0"
difficult = et.SubElement(object_, "difficult")
difficult.text = "0"
bndbox = et.SubElement(object_, "bndbox")
xmin = et.SubElement(bndbox, "xmin")
xmin.text = xmin_text
ymin = et.SubElement(bndbox, "ymin")
ymin.text = str(image.shape[0] - int(ymax_text))
xmax = et.SubElement(bndbox, "xmax")
xmax.text = xmax_text
ymax = et.SubElement(bndbox, "ymax")
ymax.text = str(image.shape[0] - int(ymin_text))
tree = et.ElementTree(root)
tree.write(image_path.replace(".jpg", "_flip.xml"), encoding="utf-8")
print(image_path, index)
index += 1
if __name__ == '__main__':
source_dir = "/home/Desktop/test"
flip_images(source_dir)
?使用以上代碼需要修改原圖像和標注文件所在文件夾路徑(source_dir)。親測可用。?
文章來源地址http://www.zghlxwxcb.cn/news/detail-668233.html
文章來源:http://www.zghlxwxcb.cn/news/detail-668233.html
到了這里,關于目標檢測任務數(shù)據(jù)集的數(shù)據(jù)增強中,圖像垂直翻轉和xml標注文件坐標調(diào)整的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網(wǎng)!