YOLOv8分割任务数据集标注流程

YOLOv8分割任务数据集标注流程

半自动化标注

这里使用了半自动化标注工具

链接:https://pan.baidu.com/s/1x22BtI_bHKH0iUUg0eTUdA

提取码:r5ca

需要指定权重和修改类别信息

配置文件中保存了类别、界面语言、轮廓模式等信息,可以通过导入配置文件来快速配置类别;也可以导出当前配置文件。

这里,我们将Main Arm类别添加进去,并删除其他多余的类型

参考文章

选择需要标注的图片文件夹,使用segment anything半自动化标注

e 完成(此时还能精细化调整)

s 保存(需要指定保存的文件夹)

JSON转TXT

需要将Labelme格式的JSON转换为YOLOv8分割格式的TXT

先将ISIA格式的JSON转换为Labelme类型

再将JSON转换为 TXT

python 复制代码
# -*- coding: utf-8 -*-
import json
import os
import argparse
from tqdm import tqdm
from PIL import Image


# 这是一个将json文件转换为YOLO格式的txt文件的脚本
def convert_label_json(json_dir, save_dir, classes):
    json_paths = os.listdir(json_dir)
    classes = classes.split(',')

    for json_path in tqdm(json_paths):
        # for json_path in json_paths:
        path = os.path.join(json_dir, json_path)
        with open(path, 'r') as load_f:
            json_dict = json.load(load_f)

        h, w = json_dict['imageHeight'], json_dict['imageWidth']

        # save txt path
        txt_path = os.path.join(save_dir, json_path.replace('json', 'txt'))
        txt_file = open(txt_path, 'w')

        for shape_dict in json_dict['shapes']:
            label = shape_dict['label']
            label_index = classes.index(label)
            points = shape_dict['points']

            points_nor_list = []

            for point in points:
                points_nor_list.append(point[0] / w)
                points_nor_list.append(point[1] / h)

            points_nor_list = list(map(lambda x: str(x), points_nor_list))
            points_nor_str = ' '.join(points_nor_list)

            label_str = str(label_index) + ' ' + points_nor_str + '\n'
            txt_file.writelines(label_str)


if __name__ == "__main__":
    """
    python json2txt_nomalize.py --json-dir my_datasets/color_rings/jsons --save-dir my_datasets/color_rings/txts --classes "cat,dogs"
    """
    parser = argparse.ArgumentParser(description='json convert to txt params')
    parser.add_argument('--json-dir', type=str, default=r'D:\dataset\Main Arm\lableme',
                        help='json path dir')
    parser.add_argument('--save-dir', type=str, default=r'D:\dataset\Main Arm\TXT',
                        help='txt save dir')
    parser.add_argument('--classes', type=str, default='Main Arm', help='classes')
    args = parser.parse_args()
    json_dir = args.json_dir
    save_dir = args.save_dir
    classes = args.classes
    convert_label_json(json_dir, save_dir, classes)

符合了YOLOv8分割标签的格式

相关推荐
AI棒棒牛5 小时前
SCI精读:基于计算机视觉改进光伏热点和积尘检测:基于现场航拍图像的YOLO模型系统比较
yolo·目标检测·计算机视觉·目标跟踪·sci
王哈哈^_^11 小时前
【完整源码+数据集】车牌数据集,yolov8车牌检测数据集 7811 张,汽车车牌识别数据集,智慧交通汽车车牌识别系统实战教程
人工智能·深度学习·yolo·目标检测·计算机视觉·毕业设计·智慧城市
FL162386312920 小时前
芸豆叶子病害检测数据集VOC+YOLO格式1762张3类别
yolo
王哈哈^_^21 小时前
【完整源码+数据集】课堂行为数据集,yolo课堂行为检测数据集 2090 张,学生课堂行为识别数据集,目标检测课堂行为识别系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计
Sunhen_Qiletian1 天前
YOLOv2算法详解(下篇):细节打磨与性能突破的终极密码
算法·yolo
Dev7z1 天前
YOLOv8改进实战:自研MSAM多尺度注意力机制,通道注意力全面升级,CBAM再进化!
yolo
Hcoco_me2 天前
YOLOv5(三):Jupyter
ide·yolo·jupyter
计算机毕业设计指导2 天前
YOLOv5+DeepSORT目标检测
人工智能·yolo·目标检测
沉默媛2 天前
如何下载安装以及使用labelme,一个可以打标签的工具,实现数据集处理,详细教程
图像处理·人工智能·python·yolo·计算机视觉
王哈哈^_^2 天前
CV三大核心任务:目标检测、图像分割、关键点检测
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测