yolo-seg二值语义分割数据集txt标签文件转换为png格式

 yolo-seg的语义分割txt标签生成png格式的0-255二值图

import cv2
import os
import shutil
import json
import numpy as np


images_path = r'test\images\\'
labels_path = r'test\labels\\'
save_images_path = r'voc_test_labels\images\\'
save_labels_path = r'voc_test_labels\labels\\'
save_visuals_path = r'voc_test_labels\visual\\'

# 提取坐标
def txt2mask_new(img_x, img_y, line):
    # 处理每一行的内容
    data = line.split('\n')[0]
    label = data.split(" ")[0]
    d = data.split(' ', -1)
    data = []
    for i in range(1, int(len(d) / 2) + 1):
        data.append([img_y * float(d[2 * i - 1]), img_x * float(d[2 * i])])
    data.append(data[0]) # 起点与终点连接
    data = np.array(data, dtype=np.int32)
    return label, data

#标签选取
def mask_select(img_path,label_path):
    #访问txt格式标签文件
    with open(label_path, "r") as f1:
        new_lines = f1.readlines()
    f1.close()

    image = cv2.imread(img_path)  # 读取图片信息
    image_h = image.shape[0]
    image_w = image.shape[1]

    visual = np.zeros((image_h, image_w, 3), np.uint8)  # 生成一张与原图大小相同的值全为0的图
    save_label = np.ones((image_h, image_w, 1), np.uint8)  # 生成一张与原图大小相同、channels为1的图片

    #txt标签处理
    for line in new_lines:
        label, data = txt2mask_new(image_h, image_w, line)
        cv2.fillPoly(visual, [data], color=(0, 0, 255)) #填充多边形,[data]:多边形顶点,围成的区域就是分割区域;color:多边形围成的区域值为(0, 0, 255)
        #生成road值为0,background为1的.png格式的语义分割标签
        cv2.fillPoly(save_label, [data], color=255) #多边形围成的区域值为0,其余为1。

    #图像标签可视化
    alpha = 1
    beta = 0.5
    save_visual = cv2.addWeighted(image, alpha, visual, beta, 0) #融合图像和标签,设置显示比例


    return 1, image, save_label, save_visual


#查询图片列表
img_items = os.listdir(images_path)
#对图片进行排序,查看自己图片命名自定义设置
# img_items.sort(key=lambda x:( "_".join(x.split("_")[:-1]), int(x.split('_')[-1].split('.jpg')[0])))
# img_items.sort(key=lambda x: (x.split('_')[-3], int(x.split('_')[-2]), int(x.split('_')[-1].split('.jpg')[0])))
# img_items.sort(key=lambda x: ("_".join(x.split("_")[:-2]), int(x.split('_')[-2]), int(x.split('_')[-1].split('.jpg')[0])))

t = 0
for i in img_items:
    print(i)
    #图像和标签路径
    image_path = os.path.join(images_path, i)
    label_path = os.path.join(labels_path, i[:-4]+".txt")

    save_image_path = save_images_path + '{}.jpg'.format(i[:-4])
    save_label_path = save_labels_path + '{}.png'.format(i[:-4])
    save_visual_path = save_visuals_path + '{}.jpg'.format(i[:-4])

    try:
        k, save_image, save_label, save_visual = mask_select(image_path, label_path)
    except FileNotFoundError as e:
        continue
    if k == 0:
        break
    elif k == 1:
        cv2.imwrite(save_image_path, save_image)
        cv2.imwrite(save_label_path, save_label)
        cv2.imwrite(save_visual_path, save_visual)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是将数据集YOLO格式标签文件转换成CSV格式的Python代码: ```python import os import csv # 指定YOLO标签文件和保存CSV文件的路径 yolo_label_file = 'path/to/yolo/label/file.txt' csv_file = 'path/to/save/csv/file.csv' # 建立CSV文件并写入表头 with open(csv_file, mode='w', newline='') as f: writer = csv.writer(f) writer.writerow(['filename', 'width', 'height', 'class', 'xmin', 'ymin', 'xmax', 'ymax']) # 读取YOLO标签文件并写入CSV文件 with open(yolo_label_file, mode='r') as f: for line in f.readlines(): # 将每一行的数据转换成列表 data = line.strip().split() # 获取文件名和图像尺寸 filename = os.path.basename(data[0]) width = int(data[1]) height = int(data[2]) # 获取物体类别和坐标信息 for i in range(3, len(data), 5): obj_class = data[i] xmin = int(data[i+1]) ymin = int(data[i+2]) xmax = int(data[i+3]) ymax = int(data[i+4]) # 将数据写入CSV文件 with open(csv_file, mode='a', newline='') as f: writer = csv.writer(f) writer.writerow([filename, width, height, obj_class, xmin, ymin, xmax, ymax]) ``` 在上面的代码中,我们首先指定了YOLO标签文件的路径和保存CSV文件的路径,然后建立CSV文件并写入表头。接着,我们读取YOLO标签文件的每一行,将每一行的数据转换成列表,并获取文件名和图像尺寸。最后,我们获取物体类别和坐标信息,并将数据写入CSV文件。 需要注意的是,上面的代码只适用于标签文件中每个物体只有一个边界框的情况。如果标签文件中每个物体有多个边界框,需要对代码进行相应的修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值