labelme 转 VOC2007 目标检测矩形框

# -*- coding: utf-8 -*-
"""
Created on Thu Sep 19 14:51:00 2019

@author: Andrea
"""

import os
import numpy as np
import codecs
import json
from glob import glob
import cv2
import shutil
from sklearn.model_selection import train_test_split
#1.标签路径
labelme_path = "F:\\fayuan1018"              #原始labelme标注数据路径
saved_path = "F:\\VOC2007-fayuan1018\\"                #保存路径

#2.创建要求文件夹
if not os.path.exists(saved_path + "Annotations"):
    os.makedirs(saved_path + "Annotations")
if not os.path.exists(saved_path + "JPEGImages/"):
    os.makedirs(saved_path + "JPEGImages/")
if not os.path.exists(saved_path + "ImageSets/Main/"):
    os.makedirs(saved_path + "ImageSets/Main/")
    
##3.获取待处理文件
#files = glob(labelme_path + "*.json")
#print(files)
#files = [i.split("/")[-1].split(".json")[0] for i in files]

#4.读取标注信息并写入 xml
#for json_file_ in files:
for json_file_ in os.listdir(labelme_path):
    if('.json' not in json_file_):
        continue
    else:
        json_file_ = json_file_.split('.json')[0]
    print(json_file_)
    json_filename = os.path.join(labelme_path , json_file_ + ".json")
    print(json_filename)
    json_file = json.load(open(json_filename,"r",encoding="utf-8"))
    print(os.path.join(labelme_path , json_file_ +".jpg"))
    height, width, channels = cv2.imread(os.path.join(labelme_path , json_file_ +".jpg")).shape
    with codecs.open(saved_path + "Annotations/"+json_file_ + ".xml","w","utf-8") as xml:
        xml.write('<annotation>\n')
        xml.write('\t<folder>' + 'UAV_data' + '</folder>\n')
        xml.write('\t<filename>' + json_file_ + ".jpg" + '</filename>\n')
        xml.write('\t<source>\n')
        xml.write('\t\t<database>The UAV autolanding</database>\n')
        xml.write('\t\t<annotation>UAV AutoLanding</annotation>\n')
        xml.write('\t\t<image>flickr</image>\n')
        xml.write('\t\t<flickrid>NULL</flickrid>\n')
        xml.write('\t</source>\n')
        xml.write('\t<owner>\n')
        xml.write('\t\t<flickrid>NULL</flickrid>\n')
        xml.write('\t\t<name>Yuanyiqin</name>\n')
        xml.write('\t</owner>\n')
        xml.write('\t<size>\n')
        xml.write('\t\t<width>'+ str(width) + '</width>\n')
        xml.write('\t\t<height>'+ str(height) + '</height>\n')
        xml.write('\t\t<depth>' + str(channels) + '</depth>\n')
        xml.write('\t</size>\n')
        xml.write('\t\t<segmented>0</segmented>\n')
        for multi in json_file["shapes"]:
            points = np.array(multi["points"])
            xmin = min(points[:,0])
            xmax = max(points[:,0])
            ymin = min(points[:,1])
            ymax = max(points[:,1])
            label = multi["label"]
            if xmax <= xmin:
                pass
            elif ymax <= ymin:
                pass
            else:
                xml.write('\t<object>\n')
                xml.write('\t\t<name>'+str(label)+'</name>\n')
                xml.write('\t\t<pose>Unspecified</pose>\n')
                xml.write('\t\t<truncated>1</truncated>\n')
                xml.write('\t\t<difficult>0</difficult>\n')
                xml.write('\t\t<bndbox>\n')
                xml.write('\t\t\t<xmin>' + str(xmin) + '</xmin>\n')
                xml.write('\t\t\t<ymin>' + str(ymin) + '</ymin>\n')
                xml.write('\t\t\t<xmax>' + str(xmax) + '</xmax>\n')
                xml.write('\t\t\t<ymax>' + str(ymax) + '</ymax>\n')
                xml.write('\t\t</bndbox>\n')
                xml.write('\t</object>\n')
                print(json_filename,xmin,ymin,xmax,ymax,label)
        xml.write('</annotation>')
        
#5.复制图片到 VOC2007/JPEGImages/下
image_files = glob(labelme_path + "*.jpg")
print("copy image files to VOC007/JPEGImages/")
for image in image_files:
    shutil.copy(image,saved_path +"JPEGImages/")
    
#6.split files for txt
txtsavepath = saved_path + "ImageSets/Main/"
ftrainval = open(txtsavepath+'/trainval.txt', 'w')
ftest = open(txtsavepath+'/test.txt', 'w')
ftrain = open(txtsavepath+'/train.txt', 'w')
fval = open(txtsavepath+'/val.txt', 'w')
total_files = glob("./VOC2007/Annotations/*.xml")
total_files = [i.split("/")[-1].split(".xml")[0] for i in total_files]
#test_filepath = ""
for file in total_files:
    ftrainval.write(file + "\n")
#test
#for file in os.listdir(test_filepath):
#    ftest.write(file.split(".jpg")[0] + "\n")
#split
train_files,val_files = train_test_split(total_files,test_size=0.15,random_state=42)
#train
for file in train_files:
    ftrain.write(file + "\n")
#val
for file in val_files:
    fval.write(file + "\n")

ftrainval.close()
ftrain.close()
fval.close()
#ftest.close()

 

<<请使用中文回答我或者给我介绍一下: 1、下载视频,2、分割视频,间隔保留1000张图片。3、安装并使用其中一种图像数据标注工具LabelImg LabelMe,将如下数据集进行矩形框标注,4、类别分别为:汽车、行人、非机动车.至少10张 1. 下载视频可以通过各种视频下载工具或网站来完成,这取决于视频的来源和格式。有些视频平台允许直接下载,有些则需要特定的下载工具。你可以使用一些浏览器插件,如Video DownloadHelper等,或者专用的下载软件,如迅雷、IDM(Internet Download Manager)等,根据视频链接进行下载。 2. 分割视频并保存特定帧数为图片,可以通过视频处理软件如FFmpeg来实现。FFmpeg是一个开源的命令行工具,用于处理多媒体数据,支持几乎所有类型的视频和音频格式换。使用FFmpeg分割视频的命令大致如下: ``` ffmpeg -i input_video.mp4 -vf "fps=1" -q:v 2 -f image2 output_%04d.png ``` 该命令表示将输入的视频文件`input_video.mp4`每秒保存一帧图片,保存为PNG格式,文件名依次为`output_0001.png`、`output_0002.png`等,直到第1000张图片。 3. 对于图像数据标注,LabelImg和LabelMe是两种常用的图像标注工具。 - LabelImg是一款专门用于图像分类和目标检测的标注工具,其界面简洁,操作方便,使用Python编写,支持Pascal VOC和YOLO格式的标注。 - LabelMe是一个基于Web的标注工具,使用JavaScript编写,它支持多种类型的标注,包括矩形、多边形、椭圆和线条,并且可以生成相应的JSON文件。 安装和使用方法如下: - LabelImg: - 下载安装:克隆LabelImg的GitHub仓库,或者下载预编译的文件到本地。 - 安装依赖:安装Python和Pip后,通过Pip安装必要的库。 - 使用:运行LabelImg的Python脚本,打开图像文件夹,进行图像选择和标注,保存标注结果。 - LabelMe: - 下载安装:访问LabelMe的GitHub页面,下载最新版本。 - 使用:运行LabelMe的Web服务,通过浏览器访问本地服务器地址进行标注。标注完成后可以导出JSON文件。 4. 对于类别"汽车、行人、非机动车"的图像数据集进行矩形框标注,你需要: - 使用上述工具打开或导入图像。 - 根据图像内容,识别并选择相应的类别(汽车、行人、非机动车)。 - 在每张图像中对应的物体周围画矩形框,并为每个框分配相应的类别标签。 - 保存标注文件,确保标注文件格式正确并且与图像文件匹配。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值