保存coco dataset注释为单一文件,并逐一显示所有图片的mask

2024-03-15 22:58

本文主要是介绍保存coco dataset注释为单一文件,并逐一显示所有图片的mask,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大意:

官方的例子只显示 一张图片,我需要逐一显示,并且官方的那个JSON文件太大了,我把注释文件分开存储,每张图片一个注释文件,另行保存在一个叫coco的文件夹中,

#
# windows version cocoapi
# https://github.com/philferriere/cocoapi
#
#
from pycocotools.coco import COCO
import numpy as np
import skimage.io as io
import json
import osimport matplotlib as mpl
mpl.use('TkAgg')
import pylab
import matplotlib.rcsetup as rcsetup
pylab.rcParams['figure.figsize'] = (8.0, 10.0)#dataDir='..'
#dataType='val2017'
#dataDir='F:/BigData/msCoco2014'
#dataType='val2014'dataDir='F:/BigData/msCoco2017'
dataType='val2017'
annFile='{}/annotations/instances_{}.json'.format(dataDir,dataType)# initialize COCO api for instance annotations
coco=COCO(annFile)# display COCO categories and supercategories
catIds = coco.getCatIds()
cats = coco.loadCats(catIds)
#print the names out
nms=[cat['name'] for cat in cats] 
print('COCO categories: \n{}\n'.format(' '.join(nms)))
#print the supercat out
nms = set([cat['supercategory'] for cat in cats])
print('COCO supercategories: \n{}'.format(' '.join(nms)))# recursively display all images and its masks
imgIds = coco.getImgIds()
for id in imgIds: annIds = coco.getAnnIds([id], catIds=catIds, iscrowd=None)anns = coco.loadAnns(annIds)imgIds = coco.getImgIds(imgIds = [id])img = coco.loadImgs(imgIds[0])[0]file_name_ext=img['file_name'](filename,extension) = os.path.splitext(file_name_ext)file_path = "coco/" + filename + ".json"data = {"annotations":anns}with open(file_path, 'w') as result_file:json.dump(data, result_file)I = io.imread('%s/%s/%s'%(dataDir,dataType,img['file_name']))mpl.pyplot.imshow(I)mpl.pyplot.axis('off')coco.showAnns(anns)

顺带再提一下coco数据集中各个参数的解释吧,一般的参数望文即可生义,只需要注意的是iscrowd,这个值为0 即表示polygon,注意,单个的对象(iscrowd=0)可能需要多个polygon来表示,比如某个对象在图像中被挡住了一部分。而iscrowd=1时,segmentation使用的就是RLE格式。

具体样式和解释参数官方文档:https://cocodataset.org/#format-data

如果是自己定义的数据集,采用coco数据格式的话,各个id到底有什么用也是需要注意的地方。

{"type": "instances","images": [{"file_name": "0.jpg","height": 600,"width": 800,"id": 0                    ----> image_id}],"categories": [{"supercategory": "none",   ----> supercategory can be anything"name": "date","id": 0                    ----> category_id},{"supercategory": "none","name": "hazelnut","id": 2},{"supercategory": "none","name": "fig","id": 1}],"annotations": [{"id": 1,                  ----> annotation id (each annotation has a unique id)"bbox": [100,116,140,170],"image_id": 0,"segmentation": [],"ignore": 0,"area": 23800,"iscrowd": 0,"category_id": 0},{"id": 2,"bbox": [321,320,142,102],"image_id": 0,"segmentation": [],"ignore": 0,"area": 14484,"iscrowd": 0,"category_id": 0}]
}

 

这篇关于保存coco dataset注释为单一文件,并逐一显示所有图片的mask的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/813532

相关文章

Rust中的注释使用解读

《Rust中的注释使用解读》本文介绍了Rust中的行注释、块注释和文档注释的使用方法,通过示例展示了如何在实际代码中应用这些注释,以提高代码的可读性和可维护性... 目录Rust 中的注释使用指南1. 行注释示例:行注释2. 块注释示例:块注释3. 文档注释示例:文档注释4. 综合示例总结Rust 中的注释

Python脚本实现图片文件批量命名

《Python脚本实现图片文件批量命名》这篇文章主要为大家详细介绍了一个用python第三方库pillow写的批量处理图片命名的脚本,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言源码批量处理图片尺寸脚本源码GUI界面源码打包成.exe可执行文件前言本文介绍一个用python第三方库pi

Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)

《Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)》本文介绍了如何使用Python和Selenium结合ddddocr库实现图片验证码的识别和点击功能,感兴趣的朋友一起看... 目录1.获取图片2.目标识别3.背景坐标识别3.1 ddddocr3.2 打码平台4.坐标点击5.图

Python利用PIL进行图片压缩

《Python利用PIL进行图片压缩》有时在发送一些文件如PPT、Word时,由于文件中的图片太大,导致文件也太大,无法发送,所以本文为大家介绍了Python中图片压缩的方法,需要的可以参考下... 有时在发送一些文件如PPT、Word时,由于文件中的图片太大,导致文件也太大,无法发送,所有可以对文件中的图

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

java获取图片的大小、宽度、高度方式

《java获取图片的大小、宽度、高度方式》文章介绍了如何将File对象转换为MultipartFile对象的过程,并分享了个人经验,希望能为读者提供参考... 目China编程录Java获取图片的大小、宽度、高度File对象(该对象里面是图片)MultipartFile对象(该对象里面是图片)总结java获取图片

使用C++将处理后的信号保存为PNG和TIFF格式

《使用C++将处理后的信号保存为PNG和TIFF格式》在信号处理领域,我们常常需要将处理结果以图像的形式保存下来,方便后续分析和展示,C++提供了多种库来处理图像数据,本文将介绍如何使用stb_ima... 目录1. PNG格式保存使用stb_imagephp_write库1.1 安装和包含库1.2 代码解

Java实战之自助进行多张图片合成拼接

《Java实战之自助进行多张图片合成拼接》在当今数字化时代,图像处理技术在各个领域都发挥着至关重要的作用,本文为大家详细介绍了如何使用Java实现多张图片合成拼接,需要的可以了解下... 目录前言一、图片合成需求描述二、图片合成设计与实现1、编程语言2、基础数据准备3、图片合成流程4、图片合成实现三、总结前

使用Python实现图片和base64转换工具

《使用Python实现图片和base64转换工具》这篇文章主要为大家详细介绍了如何使用Python中的base64模块编写一个工具,可以实现图片和Base64编码之间的转换,感兴趣的小伙伴可以了解下... 简介使用python的base64模块来实现图片和Base64编码之间的转换。可以将图片转换为Bas

css实现图片旋转功能

《css实现图片旋转功能》:本文主要介绍了四种CSS变换效果:图片旋转90度、水平翻转、垂直翻转,并附带了相应的代码示例,详细内容请阅读本文,希望能对你有所帮助... 一 css实现图片旋转90度.icon{ -moz-transform:rotate(-90deg); -webkit-transfo