import sys
import json
import cv2
import os
import shutil dataset = { "info": {
"description": "XXX in COCO dataset.",
"url": "",
"version": "1.0",
"year": ,
"contributor": "aimhabo",
"date_created": "2019-03-25"},
"images":[],
"annotations":[],
"categories": [
{"supercategory:": "person", "id": 1, "name": "person"},
{"supercategory:": "car", "id": 2, "name": "car"},
{"supercategory:": "truck", "id": 3, "name": "truck"},
{"supercategory:": "bus", "id": 4, "name": "bus"}
]
} datapath = "scripts/images"
annopath = "scripts/labels"
trainsetfile = "scripts/trainimage.list"
outputpath = "scripts"
phase = "XXXTrainCOCO"
classes = {"background": 0, "person": 1, "car": 2, "truck": 3, "bus": 4} with open(trainsetfile) as f:
count = 1
cnt = 0
annoid = 0
for line in f:
cnt += 1
line = line.strip() name,ext = os.path.basename(line).split('.') imagepath = os.path.join(datapath, name + ".jpg")
# no obstacle currently drop it
txtpath = os.path.join(annopath, name + ".txt")
if not os.path.exists(txtpath):
print txtpath
continue im = cv2.imread(imagepath) height, width, channels = im.shape if cnt % 1000 == 0:
print cnt dataset["images"].append({"license": 5, "file_name": line, "coco_url": "local", "height": height, "width": width, "flickr_url": "local", "id": cnt})
with open(txtpath) as annof:
annos = annof.readlines() for ii, anno in enumerate(annos):
parts = anno.strip().split(' ')
if len(parts) is not 5:
continue
class_id = int(parts[0])
x = float(parts[1])
y = float(parts[2])
w = float(parts[3])
h = float(parts[4])
if parts[0].find("group") == -1:
iscrowd = 0
else:
iscrowd = 1 annoid = annoid + 1 class_id += 1 # start from 1 instead of 0
x1 = int((x-w/2)*width)
y1 = int((y-h/2)*height)
wid = int(w*width)
hei = int(h*height) dataset["annotations"].append({
"segmentation": [],
"iscrowd": iscrowd,
"area": wid * hei,
"image_id": cnt,
"bbox": [x1, y1, wid, hei],
"category_id": class_id,
"id": annoid
})
count += 1 json_name = os.path.join(outputpath, "{}.json".format(phase)) with open(json_name, 'w') as f:
json.dump(dataset, f)

darknet标签转化为COCO标签的更多相关文章

  1. VOC标签转化为YOLO标签

    参考darknet自带的voc_label.py import xml.etree.ElementTree as ET import pickle import os from os import l ...

  2. 把 html标签转化为 html标签代码

    HttpUtility.HtmlEncode(table.Rows[0]["footnote"].ToString());

  3. JSP内置标签 JSP中JavaBean标签 JSP开发模式 EL和JSTL快速入门

    2 JSP内置标签(美化+业务逻辑)   1)为了取代<%%>脚本形式,使用JSP标签/JSP动作,目的:与JSP页面的美化,即JSP面页都是由标签组成,不再有其它的内容   2)JSP内 ...

  4. 初学HTML 常见的标签(三) 插入类标签

    第三篇博客, 这次说的是插入链接类标签, 我们平常在网页中经常能看到蓝色的链接类标签, 或者是一张图片, 一个电邮, 这些都是插入链接类的标签起的作用. <a></a>链接标签 ...

  5. JSTL标签库之核心标签

    一.JSTL标签库介绍 JSTL标签库的使用是为弥补html标签的不足,规范自定义标签的使用而诞生的.使用JSLT标签的目的就是不希望在jsp页面中出现java逻辑代码 二.JSTL标签库的分类 核心 ...

  6. HTML学习笔记——块级标签、行级标签、图片标签

    1>块级标签.行级标签 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "htt ...

  7. WebApp 里Meta标签大全,webappmeta标签大全

    1.先说说mate标签里的viewport: viewport即可视区域,对于桌面浏览器而言,viewport指的就是除去所有工具栏.状态栏.滚动条等等之后用于看网页的区域.对于传统WEB页面来说,9 ...

  8. meta标签详解(meta标签的作用)///////////////////////////转

    meta标签详解(meta标签的作用) 很多人却忽视了HTML标签META的强大功效,一个好的META标签设计可以大大提高你的个人网站被搜索到的可能性,有兴趣吗,谁我来重新认识一下META标签吧   ...

  9. <script>标签应该放到</body>标签之前

    著作权归作者所有. 商业转载请联系作者获得授权,非商业转载请注明出处. 作者:贺师俊 链接:http://www.zhihu.com/question/20027966/answer/13727164 ...

随机推荐

  1. Codeforces Round #597 (Div. 2) A. Good ol' Numbers Coloring

    链接: https://codeforces.com/contest/1245/problem/A 题意: Consider the set of all nonnegative integers: ...

  2. 使用JSP/Servalet技术开发新闻发布系统------动态网页开发基础

    什么是动态网页? 动态网页是指在服务器端运行的程序或者网页,它们会随不同客户.不同时间,返回不同的网页. 动态网页的特点? (1).交互性:即网页会根据用户的要求和选择而动态改变和响应.采用动态网页技 ...

  3. git 文件名大小写不敏感

    1. 通过修改 git 配置: git config core.ignorecase false 2. 强制执行修改文件名命令: 需要重命名已添加到git的文件时,git mv --f oldFile ...

  4. P1608 路径统计

    题目描述 “RP餐厅”的员工素质就是不一般,在齐刷刷的算出同一个电话号码之后,就准备让HZH,TZY去送快餐了,他们将自己居住的城市画了一张地图,已知在他们的地图上,有N个地方,而且他们目前处在标注为 ...

  5. wepy代码知识点

    index-page <style lang="less"> .index-nood-modal { width: 100vw; height: 100vh; posi ...

  6. 洛谷P2305 [NOI2014]购票 [DP,树状数组]

    传送门 思路 显然是树形DP,显然是斜率优化,唯一的问题就是该怎么维护凸包. 套路1:树上斜率优化,在没有这题的路程的限制的情况下,可以维护一个单调栈,每次加入点的时候二分它会加到哪里,然后替换并记录 ...

  7. Airflow 配置celery+rabbitmq和celery+redis

    Airflow 配置celery+rabbitmq 1.安装celery和rabbitmq组件 pip3 install apache-airflow[celery] pip3 install apa ...

  8. python常用函数1

    map()函数 map()是python 内置 的高届函数 ,接收一个函数  f  和一个list,并通过把函数  f  依次作用在list的每个元素上,得到一个新的 list 并返回. 比如,对于l ...

  9. Java8 JVM参数解读

    附录:https://www.liangzl.com/get-article-detail-134315.html 摘要: 我们知道java虚拟机启动时会带有很多的启动参数,Java命令本身就是一个多 ...

  10. 小福bbs-凡事预则立

    [小福bbs-凡事预则立] 1.冲刺的时间计划安排(冲刺时间为期七天,安排在2019-11-3--2019-11-14之间) 冲刺的时间 计划安排 2019.11.7 开会,安排具体工作 2019.1 ...