根据分割图生成bbox的csv标注:

根据分割图生成bbox的csv标注:

import numpy as np
import skimage
from skimage.measure import label,regionprops
from skimage.filters import roberts
import os
import cv2
import pandas as pd

def get_patch_csv(filename_list, root_dir, output_path, area_thr = 9):
    # take the pred mask of segmention 
    annotation = pd.DataFrame()
    name_list = []
    x1_list = []
    y1_list = []
    x2_list = []
    y2_list = []
    bbox_id_list = []
    Bounding_boxes_list = []
    for filename in filename_list:
        im_path = os.path.join(root_dir, filename)
        img = cv2.imread(im_path)
        if len(img.shape)>2:
            img = img[:,:,0]
        label_img = label(img)
        bbox_id = 0
        for r in regionprops(label_img):
            if r.area < area_thr:
                continue
            name_list.append(filename[0:-3] + 'png')
            bbox_id_list.append(bbox_id)
            bbox_id += 1
            x1_list.append(r.bbox[1])
            y1_list.append(r.bbox[0])
            x2_list.append(r.bbox[3])
            y2_list.append(r.bbox[2])
            Bounding_boxes_list.append(','.join([str(r.bbox[i]) for i in [1,0,3,2]]))
    annotation['File_name'] = name_list
    annotation['bbox_id'] = bbox_id_list
    annotation['bbox_x1'] = x1_list
    annotation['bbox_y1'] = y1_list
    annotation['bbox_x2'] = x2_list
    annotation['bbox_y2'] = y2_list
    annotation['Bounding_boxes'] = Bounding_boxes_list
    annotation.to_csv(output_path)

if __name__ == "__main__":
    root_dir = ''
    output_path = 'xxx/seg_info.csv'
    filename_list = os.listdir(root_dir)
    get_patch_csv(filename_list, root_dir, output_path)
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值