PASCAL VOC 2012数据集及数据集划分

本文介绍如何使用Python脚本生成类似PASCALVOC2012的数据集划分,包括train.txt和val.txt,通过随机采样确保划分的可重复性,适用于FasterRCNN等目标检测模型训练。
摘要由CSDN通过智能技术生成

 1、数据集文件结构

2、PASCAL VOC 2012数据集下载

地址:http://host.robots.ox.ac.uk/pascal/VOC/voc2012/index.html#devkit

3、生成txt文件

在得到自己标注好的数据后,如何得到像VOC 2012那样的train.txt文件呢?

import os
import random


def main():
    random.seed(0)  # 设置随机种子,保证随机结果可复现
    # files_path 地址
    files_path = "./VOCdevkit/VOC2012/Annotations"
    # 判断文件地址是否存在
    assert os.path.exists(files_path), "path: '{}' does not exist.".format(files_path)
    # 测试集比例
    val_rate = 0.5
    """
        for file in os.listdir(files_path)
            其中os.listdir(files_path)遍历该路径下所有的文件
            file就是一个一个文件
        file.split(".")[0]
            分割字符串并取出文件名
        sorted()
            排序函数
        Note: 列表表达式最后得到肯定是一个list
    """
    files_name = sorted([file.split(".")[0] for file in os.listdir(files_path)])
    # 文件数量
    files_num = len(files_name)
    """
        random.sample(序列,k=采样个数)
            可以简单理解为从某个list中随机采样k个点(且k不会重复)
            返回值是一个list
                >>> import random
                >>> random.sample(range(0, 10), 6)
                [8, 3, 7, 0, 6, 2]
                
        random.sample(range(0, files_num), k=int(files_num*val_rate))
            从0到files_num-1中随机采样files_num*val_rate个点组成一个list并返回
    """
    val_index = random.sample(range(0, files_num), k=int(files_num*val_rate))
    train_files = []
    val_files = []
    # files_name是一个list,list可以被enumerate
    for index, file_name in enumerate(files_name):
        if index in val_index: # 如果这张图片是采样图片,则放入验证集
            val_files.append(file_name)
        else:
            train_files.append(file_name)

    try:
        # 'x'用于创建并写入新文件
        # \n 表示换行符
        train_f = open("train.txt", "x")
        eval_f = open("val.txt", "x")
        train_f.write("\n".join(train_files))
        eval_f.write("\n".join(val_files))
    except FileExistsError as e:
        print(e)
        exit(1)


if __name__ == '__main__':
    main()

1.2Faster RCNN源码解析(pytorch)-霹雳吧啦Wz-深度学习-目标检测篇-哔哩哔哩视频 (bilibili.com)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值