import os
import xml.etree.ElementTree as ET
import cv2 origin_ann_dir = 'D:/Data/MyAnnoData/vmwareData/Annotations/'
new_ann_dir = 'D:/Data/MyAnnoData/vmwareData/save/Annotations/'
new_img_dir = 'D:/Data/MyAnnoData/vmwareData/save/JPEGImages/'
image_dir = 'D:/Data/MyAnnoData/vmwareData/JPEGImages/' #for dirpaths, dirnames, filenames in os.walk(origin_ann_dir):
# for filename in filenames: #xml文件名
file = open("D:/Data/MyAnnoData/vmwareData/0.txt")
for filename in file:
filename = filename.strip("\n")
# if os.path.isfile(r'%s%s' % (origin_ann_dir, filename)):
# origin_ann_path = os.path.join(r'%s%s' % (origin_ann_dir, filename))
# new_ann_path = os.path.join(r'%s%s' % (new_ann_dir, filename)) origin_ann_path = origin_ann_dir + filename
new_ann_path = new_ann_dir + filename
tree = ET.parse(origin_ann_path)
root = tree.getroot() for image_size in root.findall('size'):
imgwidth = int(image_size.find('width').text) #读取图像宽度
imgheight = int(image_size.find('height').text) #读取图像高度 image_size.find('width').text = str(imgwidth)
image_size.find('height').text = str(imgheight) image_name =filename.split('.xml')
imgpath = image_dir + image_name[0] + '.jpg'
img = cv2.imread(imgpath)
if not img.data:
break maxl = max(imgheight, imgwidth) #图片size是maxl*maxl
paddingleft = (maxl - imgwidth) >> 1
paddingright = (maxl - imgwidth) >> 1
paddingbottom = (maxl - imgheight) >> 1
paddingtop = (maxl - imgheight) >> 1
saveimg = cv2.copyMakeBorder(img, paddingtop, paddingbottom, paddingleft, paddingright, cv2.BORDER_CONSTANT,value=0)
cv2.imwrite(new_img_dir + image_name[0] + '.jpg', saveimg) for image_size in root.findall('size'):
image_size.find('width').text = str(maxl)
image_size.find('height').text = str(maxl) for object in root.findall('object'):
name = str(object.find('name').text) #标注对象名
v_bndbox = object.find('bndbox') #目标框位置
x1 = int(v_bndbox.find('xmin').text)
y1 = int(v_bndbox.find('ymin').text)
x2 = int(v_bndbox.find('xmax').text)
y2 = int(v_bndbox.find('ymax').text) x11 = x1 + paddingleft
y11 = y1 + paddingtop
x22 = x11 + (x2-x1+1)
y22 = y11 + (y2-y1+1) v_bndbox.find('xmin').text = str(x11)
v_bndbox.find('ymin').text = str(y11)
v_bndbox.find('xmax').text = str(x22)
v_bndbox.find('ymax').text = str(y22) print(filename)
tree.write(new_ann_path)

修改xml成正方形,保存的更多相关文章

  1. Dom4j修改xml文档引入

    前面介绍了如何解析xnl文档的内容,这里对修改xml展开讨论. 一.首先看一下,写出内容到xml文档的主要代码: XMLWriter writer = new XMLWriter(OutputStre ...

  2. Java xml 操作(Dom4J修改xml   + xPath技术  + SAX解析 + XML约束)

    1 XML基础 1)XML的作用 1.1 作为软件配置文件 1.2 作为小型的"数据库" 2)XML语法(由w3c组织规定的) 标签: 标签名不能以数字开头,中间不能有空格,区分大 ...

  3. xml基本操作和保存配置文件应用实例

    引言:在实际项目中遇到一些关于xml操作的问题,被逼到无路可退的时候终于决定好好研究xml一番.本文首先介绍了xml的基本操作,后面写了一个经常用到的xml保存配置文件的实例. xml常用方法: 定义 ...

  4. C#创建XML文件并保存

    随着XML的普及以及在动态WEB应用程序中大量应用,如何通过.NET创建,删除,修改XML文件变的也来也重要了.一个简单的概念是,XML文件跟大的文本文件并没有什么区别,同时它是先于.NET出现,很多 ...

  5. 06_XML的写入_dom4j添加、删除、修改Xml文件内容

    [工程截图] [person.xml]准备一个xml文件 <?xml version="1.0" encoding="UTF-8"?> <st ...

  6. webservice04#对象与xml转换-jaxb#Stax解析xml#新建修改xml

    1,Student类 package com.yangw.xml; import javax.xml.bind.annotation.XmlRootElement; @XmlRootElement / ...

  7. Java&Xml教程(三)使用DOM方式修改XML文件内容

    DOM解析方式也可用于修改XML数据,我们可以使用它完成新增元素.删除元素.修改元素值.修改元素属性等操作. 我们的XML文件,内容如下: employee.xml <?xml version= ...

  8. javafx这些学会后,开发就不难了,往tablecloumn列中添加按钮,修改javafx中tableview中tablecell中的值,修改完回车表示保存到内存中

    javafx开发过程中遇见难题,往tablecloumn列中添加按钮 想了很久的方法,也配有办法判断每行中有数据的地方添加按钮set bank_caozuo.setCellFactory((col)- ...

  9. Android studio中修改xml文件无效问题

    昨天遇到的这个问题,在修改布局xml文件后保存,但运行时布局却并没有被修改,也就是说我的修改无效,今天参照了这篇文章中的方法终于解决了: https://blog.csdn.net/l_o_s/art ...

随机推荐

  1. BigDecimal源码

    1 public BigDecimal(char[] in, int offset, int len, MathContext mc) {// 使用字符数组的构造方法,一般我们推荐使用的是一Strin ...

  2. c# ASP.NET Core2.2利用中间件支持跨域请求

    1.public void Configure(IApplicationBuilder app, IHostingEnvironment env)方法里面 不要加上:app.UseCors(); 2. ...

  3. Python练习:爬虫练习,从一个提供免费代理的网站中爬取IP地址信息

    西刺代理,http://www.xicidaili.com/,提供免费代理的IP,是爬虫程序的目标网站. 开始写程序 import urllib.requestimport re def open_u ...

  4. 运行main方法找不到类

    http://blog.csdn.net/chenleixing/article/details/44816629

  5. 煎蛋ooxx

    pipeline.py class Jiandanline(FilesPipeline): def get_media_requests(self, item, info): for file_url ...

  6. 内存泄漏(I)

    Block 解决内存泄漏 使用 weakSelf 进行解决 NSTimer 的内存泄漏与解决方案 内存泄漏

  7. js数组创建两种方法

    一.数组直接量形式创建数组 var arr=[];//空数组 ,,,,,]; ,,,],{x:,y:}]; ; ,x+,x+]; console.log(arr3); //[1,3,3,4] ,,]; ...

  8. maven打包并上传到nexus3私服

    之前搭了个maven私服,接下来则要充分利用这个私服的优势上传自己的jar包了. 我们先在nexus上创建一个用来上传jar包的角色,并通过此角色创建若干帐号用来给开发者上传包.如图是我自己的配置: ...

  9. PAT (Advanced Level) Practice 1001 A+B Format (20 分)

    题目链接:https://pintia.cn/problem-sets/994805342720868352/problems/994805528788582400 Calculate a+b and ...

  10. 高版本mysql8.0解压版安装步骤

    解压版安装操作官网下载: mysql-installer-community-8.0.12.0.msi如上操作: http://www.cnblogs.com/elfin/p/9429877.html ...