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. Jmeter笔记(Ⅱ)使用Jmeter实现轻量级的接口自动化测试

    接口测试虽然作为版本的一环,但是也是有一套完整的体系,有接口的功能测试.性能测试.安全测试:同时,由于接口的特性,接口的自动化低成本高收益的,使用一些开源工具或一些轻量级的方法,在测试用例开发的成本不 ...

  2. Spring Cloud Gateway Ribbon 自定义负载均衡

    在微服务开发中,使用Spring Cloud Gateway做为服务的网关,网关后面启动N个业务服务.但是有这样一个需求,同一个用户的操作,有时候需要保证顺序性,如果使用默认负载均衡策略,同一个用户的 ...

  3. Excel坐标自动在AutoCad绘图_6

    众所周知,Excel对数据处理的功能非常强大,它可以进行数据处理.统计分析已经辅助决策的操作,该软件已经渗透到各个领域.作为一个测绘人,GISer, 也经常利用excel完成一些测量表格的自动化计算, ...

  4. tcpdf中增加微软雅黑的正确方式

    找了很多增加字体的方式,不过提供的命令行下增加字体的命令是错误的,下面这个命令是验证过可以用的,不管是win还是linux活着mac都可以. tcpdf对中文的支持就不太好, 当然也可以支持, 比如里 ...

  5. 03-python3.5-模拟购物车流程--更新追加细节注释功能

    03-python3.5-模拟购物车流程--更新追加细节注释功能: 模拟购物车更新脚本: #!/usr/bin/env python #-*- coding: utf-8 -*- #__author_ ...

  6. 宝塔安装swoole

    新建文件夹 mkdir swoole 切入到文件夹中,进行下载安装包 wget http://pecl.php.net/get/swoole-4.3.2.tgz 解压 tar -zxvf swoole ...

  7. v-charts简介

    一, v-charts简介 在使用 echarts 生成图表时,经常需要做繁琐的数据类型转化.修改复杂的配置项,v-charts 的出现正是为了解决这个痛点.基于 Vue2.0 和 echarts 封 ...

  8. WEUI滚动加载

    var row = 6, page = 1; var loading = false; //状态标记 $(document.body).infinite().on("infinite&quo ...

  9. Navicat Premium for Mac完美破解

    前因:系统升级Mojave10.14.4,没升级成功,也可能是误删了系统下的private文件夹下的东西,导致内核崩溃.    自己鼓捣了下,恢复系统不成功,去苹果售后问了下,重装系统399,保留资料 ...

  10. LOJ #10070 最小生成树计数

    一道mst-- 最开始是毫无头绪,于是就点开了--->题解 大部分题解都是矩阵树--然而第一篇题解告诉了我们暴搜也能过( 思路大概是说,对于一个图\(G\),它的所有最小生成树的相同权值的边的数 ...