python用opencv将标注提取画框到对应的图像中
作者:徽先生 发布时间:2023-01-18 21:10:16
标签:python,opencv,标注,提取,画框
前言
问题需求:
拥有两个文件夹,一个保存图片image,一个保存标签文件,要求把标签文件中的标注提取出来,并在图片中画出来
相应的思路
首先提出各个文件的路径;
然后将解析json文件,将其中的标注文件提取,并将对应的图像读取在图像上将对应的框画出来;由于图像以及标签的文件前缀都是一样的,所以只要一个前缀列表提取出来,然后将图像的路径与其进行拼接(图像路径+前缀+.jpeg)就可以读取对应的图像,而写入的图像也是一样(写入图像路径+前缀+.jpeg),标签文件也是一样(标签路径+前缀+.json)
读取前缀列表
通过
os.walk()
迭代读取文件夹以及相应的文件列表通过
os.listdir
直接读取文件夹下的文件列表
# 通过os.walk()读取文件夹以及相应的文件列表
def get_file_list(path):
file_list=[]
for dir_list,folder,file in os.walk(path):
file_list=file
return file_list
#通过os.listdir()读取文件夹下的文件列表
def get_file_list2(path):
file_list=os.listdir(path)
return file_list
file_list=get_file_list2(r"E:\temp\AI\label")
print(file_list)
找出json结构中对应框坐标位置,画出对应的框
查看json文件结构,对应找到坐标所在的位置:
可以看到json文件中坐标是在shapes对应的points里的列表,而且是列表第0项表示左上位置,而第一项表示右上位置,所以在cv2的画框的两个参数参数pt1和pt2就定下来
cv2.rectangle(img, pt1, pt2, color, thickness=None )
{
"version": "3.16.5",
"flags": {},
"shapes": [
{
"label": "0",
"line_color": null,
"fill_color": null,
"points": [
[
2720.0,
1094.0
],
[
2768.0,
1158.0
]
],
"shape_type": "rectangle",
"flags": {}
}
],
...
}
那么代码就如下所示:
import json
import cv2
path_label=r"E:\temp\AI\label"
path_img=r"E:\temp\AI\image"
path_result=r"E:\temp\AI\result"
# 通过遍历将图像纷纷画框
for file in file_list:
txt=open(os.path.join(path_label,file))
load_json=json.load(txt)
for shape in load_json["shapes"]:
left_top=(int(shape["points"][0][0]),int(shape["points"][0][1]))
right_bottom=(int(shape["points"][1][0]),int(shape["points"][1][1]))
#对象进行画框
img_name=file.split(".")[0]+".jpeg"
img=cv2.imread(os.path.join(os.path.join(path_img,img_name)))
cv2.rectangle(img, left_top,right_bottom, (0, 255, 0), 2)
cv2.imwrite(os.path.join(path_result,img_name), img)
比如其中一个图像的一个缺陷位置就被标注出来
来源:https://blog.csdn.net/weixin_42295969/article/details/126414920
0
投稿
猜你喜欢
- 摘要在Nginx和uWSGI还没配置时,单独在url.py使用apscheduler设置定时任务,使用python manage.py ru
- 题目:在提示符下使用open打开一个文件刚开始网上看了下打开的方式,结果一直实现不了,报错是没找到这个文件,而且和我输入的文件名不一样。错误
- 前言:c3p0 是一个开源的数据库连接池,实现了 JDBC 3 规范;本文主要介绍 c3p0 的基本使用,文中使用到的软件版本:Java 1
- 使用全局路由守卫实现前端定义好路由,并且在路由上标记相应的权限信息const routerMap = [ { path: '/per
- 前言最近不小心把硬盘给格式化了,由于当时的文件没有备份,所以一下所有的文件都没有了,于是只能采取补救措施,用文件恢复软件恢复了一部分的数据出
- 场景:服务器数据库需要实现每天定时备份1.首先确定备份脚本放置位置个人放置在 /usr/local/backup文件
- 依赖库flask安装,使用豆瓣源加速。pip install flask -i https://pypi.douban.com/simple
- 一、概述变量的功能是存储用户的数据二、声明变量Go语言的每一个变量都拥有自己的类型,必须经过声明才能开始用变量的声明格式:var <变
- python常见的错误有1.NameError变量名错误2.IndentationError代码缩进错误3.AttributeError对象
- 安装pip install faker使用简单使用本库可生成姓名、地址、电话、邮箱、公司等等一系列数据。首先导入库,实例化:from fak
- 一、概述OLAP的系统(即Online Aanalyse Process)一般用于系统决策使用。通常和数据仓库、数据分析、数据挖掘等概念联系
- 以这个为例: yyyy-MM-dd HH:mm:ss首先得写好你需要的模板options.sign =
- 进程想要执行任务就需要依赖线程。换句话说,就是进程中的最小执行单位就是线程,并且一个进程中至少有一个线程。那什么是多线程?提到多线程这里要说
- 前言事情是这样的马上就快到毕业季了,大四的学姐们快要离校了你心中那个没有说出口的学姐,你还记得吗跟着博主,用pygame给你心中那个学姐做一
- 背景:有一个list,里面的每一个元素都是dict,根据某一个key进行去重,在这里,key代表question#!/usr/bin/env
- 需求是在某一指定的时刻执行操作网上的建议多为通过调用Scheduler的add_date_job实现不过APScheduler 3.0.1与
- 有时候需要制造一些测试的数据,以mysql官方给的测试库为基础,插入十万,百万或者千万条数据。利用一些函数和存储过程来完成。官方给的测试库地
- 前言最近需要源码部署一个项目,因此探索一下保护源码的方式,由简单到复杂主要总结为以下三大类:代码混淆:主要是改变一些函数名、变量名代码打包:
- Keras应该是最简单的一种深度学习框架了,入门非常的简单.简单记录一下keras实现多种分类网络:如AlexNet、Vgg、ResNet采
- 目录1. 字符串拆分函数.split()2. 字符串拼接函数.join()扩展:理解" ".join(s.split(&