深度学习数据集分割json文件转目标检测txt文件

平时在网上找数据集或者师兄师姐给到的数据集有部分是做分割的数据集,标注是以矩形框的形式进行标注的,而我们现在常用的目标检测所使用的数据集一般是按照矩形框进行标注的,这里给出一种json转txt的方法(需要json转png+txt私聊),整体思路大概是获取多边形标注框的所有坐标点的最大最小坐标,达到框选整个目标的需求。

效果如可以看下图,所有的类别和标注框都正常,右图为json标注效果,左图为转换后txt效果

代码如下

import os
import json

# 定义JSON文件夹路径和输出txt文件夹路径
json_folder = r'f:\111' #修改为json文件夹
output_txt_folder = r'f:\333' #修改为输出txt文件夹

# 类别列表
category_list = ["Tailings Ponds", "Bare Land", "Water Reservoir"] #这里需要修改列出所有标签

# 列出文件夹中的所有JSON文件
json_files = [f for f in os.listdir(json_folder) if f.endswith('.json')]

for json_file in json_files:
    with open(os.path.join(json_folder, json_file), 'r') as f:
        data = json.load(f)

    output_txt_path = os.path.join(output_txt_folder, json_file.replace('.json', '.txt'))

    with open(output_txt_path, 'w') as txt_file:

        for shape in data['shapes']:
            category = category_list.index(shape['label'])
            points = shape['points']
            x_values = [point[0] for point in points]
            y_values = [point[1] for point in points]
            x_min = min(x_values)
            x_max = max(x_values)
            y_min = min(y_values)
            y_max = max(y_values)

            x_center = max(0, (x_min + x_max) / 2.0 / data['imageWidth'])
            y_center = max(0, (y_min + y_max) / 2.0 / data['imageHeight'])
            width = max(0, (x_max - x_min) / data['imageWidth'])
            height = max(0, (y_max - y_min) / data['imageHeight'])
            txt_file.write(f"{category} {x_center} {y_center} {width} {height}\n")

    print(f"Saved normalized coordinates to: {output_txt_path}")

  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用Imgaug库对labelme标注后的json格式数据集进行语义分割的扩充,你需要对标注的掩码进行增强。 首先,你可以按照前面提到的方法加载labelme标注后的json数据集。然后,你需要将标注的掩码换为可处理的形式,例如使用Numpy数组。 下面是一个示例代码,用于将labelme标注后的json掩码换为Numpy数组: ```python import numpy as np from labelme import utils def json_to_mask(json_data): height = json_data['imageHeight'] width = json_data['imageWidth'] mask = np.zeros((height, width), dtype=np.uint8) for shape in json_data['shapes']: label = shape['label'] polygon = shape['points'] mask = utils.shape_to_mask((height, width), polygon, shape_type='polygon') mask = np.where(mask, label, mask) return mask mask = json_to_mask(json_data) ``` 接下来,你可以使用Imgaug库来定义并应用各种图像增强技术。例如,你可以使用以下代码来实现随机水平翻和随机旋的图像增强: ```python import imgaug.augmenters as iaa # 定义图像增强器 augmenter = iaa.Sequential([ iaa.Fliplr(0.5), # 随机水平翻概率为50% iaa.Affine(rotate=(-45, 45)) # 随机旋角度范围为-45到45度 ]) # 对每个标注的掩码进行增强 augmented_masks = [] for mask in masks: augmented_mask = augmenter.augment_image(mask) augmented_masks.append(augmented_mask) ``` 在这个示例中,我们将增强后的掩码存储在一个列表中,你可以根据自己的需求进行后续处理,例如保存增强后的掩码。 需要注意的是,语义分割的标注通常是像素级别的,因此你需要确保图像增强器同时应用于图像和对应的掩码,以保持它们的一致性。 希望这个回答能对你有帮助!如果你还有其他问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值