python目标检测给图画框,bbox画到图上并保存案例


Posted in Python onMarch 10, 2020

我就废话不多说了,还是直接上代码吧!

import os
import xml.dom.minidom
import cv2 as cv
 
ImgPath = 'C:/Users/49691/Desktop/gangjin/gangjin_test/JPEGImages/'
AnnoPath = 'C:/Users/49691/Desktop/gangjin/gangjin_test/Annotations/' #xml文件地址
save_path = ''
def draw_anchor(ImgPath,AnnoPath,save_path):
  imagelist = os.listdir(ImgPath)
  for image in imagelist:
 
    image_pre, ext = os.path.splitext(image)
    imgfile = ImgPath + image
    xmlfile = AnnoPath + image_pre + '.xml'
    # print(image)
    # 打开xml文档
    DOMTree = xml.dom.minidom.parse(xmlfile)
    # 得到文档元素对象
    collection = DOMTree.documentElement
    # 读取图片
    img = cv.imread(imgfile)
 
    filenamelist = collection.getElementsByTagName("filename")
    filename = filenamelist[0].childNodes[0].data
    print(filename)
    # 得到标签名为object的信息
    objectlist = collection.getElementsByTagName("object")
 
    for objects in objectlist:
      # 每个object中得到子标签名为name的信息
      namelist = objects.getElementsByTagName('name')
      # 通过此语句得到具体的某个name的值
      objectname = namelist[0].childNodes[0].data
 
      bndbox = objects.getElementsByTagName('bndbox')
      # print(bndbox)
      for box in bndbox:
        x1_list = box.getElementsByTagName('xmin')
        x1 = int(x1_list[0].childNodes[0].data)
        y1_list = box.getElementsByTagName('ymin')
        y1 = int(y1_list[0].childNodes[0].data)
        x2_list = box.getElementsByTagName('xmax')  #注意坐标,看是否需要转换
        x2 = int(x2_list[0].childNodes[0].data)
        y2_list = box.getElementsByTagName('ymax')
        y2 = int(y2_list[0].childNodes[0].data)
        cv.rectangle(img, (x1, y1), (x2, y2), (255, 255, 255), thickness=2)
        cv.putText(img, objectname, (x1, y1), cv.FONT_HERSHEY_COMPLEX, 0.7, (0, 255, 0),
              thickness=2)
        # cv.imshow('head', img)
        cv.imwrite(save_path+'/'+filename, img)  #save picture

补充知识:深度学习python之用Faster-rcnn 检测结果(txt文件) 在原图画出box

使用Faster-rcnn 的test_net.py 检测网络的mAP等精度会生成一个检测结果(txt文件),格式如下:

000004 0.972 302.8 94.5 512.0 150.0
000004 0.950 348.1 166.1 512.0 242.9
000004 0.875 1.0 25.7 292.6 126.3
000004 0.730 1.0 138.5 488.3 230.0
000004 0.699 1.0 120.9 145.5 139.9
000004 0.592 54.4 227.4 431.9 343.4
000004 0.588 1.0 159.8 18.8 231.6
000004 0.126 1.0 247.1 342.3 270.0
000004 0.120 1.0 225.4 185.7 309.3

每行分别为 名称 检测概率 xmin ymin xmax ymax

问题在于每一行只显示一个box数据,每幅图像可能包括多个box,需要判断提取的多行数据是不是属于同一图片

下面使用python提取这些数据,在原图上画出box并且保存起来

import os
import os.path
import numpy as np
import xml.etree.ElementTree as xmlET
from PIL import Image, ImageDraw
import cPickle as pickle 

txt_name = 'comp4_8a226fd7-753d-40fc-8013-f68d2a465579_det_test_ship.txt'
file_path_img = '/home/JPEGImages'
save_file_path = '/home/detect_results'


source_file = open(txt_name)

img_names = []
for line in source_file:
  staff = line.split()
  img_name = staff[0]
  img_names.append(img_name)

name_dict = {}
for i in img_names:
  if img_names.count(i)>0:
    name_dict[i] = img_names.count(i) 

source_file.close()

source_file = open(txt_name)
for idx in name_dict:
  img = Image.open(os.path.join(file_path_img, idx + '.jpg')) 
  draw = ImageDraw.Draw(img)
  for i in xrange(name_dict[idx]):
    line = source_file.readline()
    staff = line.split()
    score = staff[1]
    box = staff[2:6]
    draw.rectangle([int(np.round(float(box[0]))), int(np.round(float(box[1]))), 
          int(np.round(float(box[2]))), int(np.round(float(box[3])))], outline=(255, 0, 0))
  img.save(os.path.join(save_file_path, idx + '.jpg')) 

source_file.close()

运行完即可在保存文件夹中得到效果图。

以上这篇python目标检测给图画框,bbox画到图上并保存案例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
使用Python制作获取网站目录的图形化程序
May 04 Python
微信跳一跳自动运行python脚本
Jan 08 Python
浅谈Python中重载isinstance继承关系的问题
May 04 Python
在cmd命令行里进入和退出Python程序的方法
May 12 Python
Python subprocess模块常见用法分析
Jun 12 Python
Python面向对象之继承和组合用法实例分析
Aug 27 Python
Python3.4 splinter(模拟填写表单)使用方法
Oct 13 Python
Python字符串大小写转换拼接删除空白
Sep 19 Python
Django框架下静态模板的继承操作示例
Nov 08 Python
python中常见错误及解决方法
Jun 21 Python
使用Keras预训练好的模型进行目标类别预测详解
Jun 27 Python
Python 数据可视化神器Pyecharts绘制图像练习
Feb 28 Python
python opencv 检测移动物体并截图保存实例
Mar 10 #Python
Python标准库json模块和pickle模块使用详解
Mar 10 #Python
Python xlrd excel文件操作代码实例
Mar 10 #Python
python图片剪裁代码(图片按四个点坐标剪裁)
Mar 10 #Python
python 截取XML中bndbox的坐标中的图像,另存为jpg的实例
Mar 10 #Python
Python代码一键转Jar包及Java调用Python新姿势
Mar 10 #Python
Python读取VOC中的xml目标框实例
Mar 10 #Python
You might like
PHP 实用代码收集
2010/01/22 PHP
PHP中__get()和__set()的用法实例详解
2013/06/04 PHP
去除php注释和去除空格函数分享
2014/03/13 PHP
PHP获取文件夹内文件数的方法
2015/03/12 PHP
php面向对象值单例模式
2016/05/03 PHP
Laravel学习教程之路由模块
2017/08/18 PHP
JavaScript 对象的属性和方法4种不同的类型
2010/03/19 Javascript
jquery下为Event handler传递动态参数的代码
2011/01/06 Javascript
《JavaScript高级程序设计》阅读笔记(三) ECMAScript中的引用类型
2012/02/27 Javascript
如何使用jQUery获取选中radio对应的值(一句代码)
2013/06/03 Javascript
收集json解析的四种方法分享
2014/01/17 Javascript
JavaScript的内存释放问题详解
2015/01/21 Javascript
两种js监听滚轮事件的实现方法
2016/05/13 Javascript
详解js产生对象的3种基本方式(工厂模式,构造函数模式,原型模式)
2017/01/09 Javascript
Vue.2.0.5过渡效果使用技巧
2017/03/16 Javascript
bootstrap下拉框动态赋值方法
2018/08/10 Javascript
使用puppeteer爬取网站并抓出404无效链接
2018/12/20 Javascript
javascript验证form表单数据的案例详解
2019/03/25 Javascript
vue router动态路由设置参数可选问题
2019/08/21 Javascript
Vue form表单动态添加组件实战案例
2019/09/02 Javascript
vue中的v-model原理,与组件自定义v-model详解
2020/08/04 Javascript
[48:00]EG vs LGD 2018国际邀请赛淘汰赛BO3 第二场 8.26
2018/08/29 DOTA
查看TensorFlow checkpoint文件中的变量名和对应值方法
2018/06/14 Python
python使用thrift教程的方法示例
2019/03/21 Python
python中while和for的区别总结
2019/06/28 Python
python求numpy中array按列非零元素的平均值案例
2020/06/08 Python
详解在Python中使用Torchmoji将文本转换为表情符号
2020/07/27 Python
Geekbuying波兰:购买中国电子产品
2019/10/20 全球购物
Brasty罗马尼亚:购买手表、香水、化妆品、珠宝
2020/04/21 全球购物
意大利时尚奢侈品店:D’Aniello Boutique
2021/01/19 全球购物
广告创意求职信
2014/03/17 职场文书
2014年党员公开承诺书范文
2014/03/28 职场文书
和谐社区口号
2014/06/19 职场文书
毕业生登记表班级意见
2015/06/05 职场文书
负责培养人意见
2015/06/05 职场文书
Vue如何实现组件间通信
2021/05/15 Vue.js