「小土堆」pytorch DataSet

「小土堆」pytorch DataSet

python 复制代码
from cProfile import label

from torch.utils.data import Dataset
from PIL import Image
import os

class MyData(Dataset):
    def __init__(self, root_dir, label_dir):

        # root_dir = "hymenoptera_data/train"
        # label_dir = "ants_img"
        # 这两个值是由后面的实例传递过来的
        self.root_dir = root_dir
        self.label_dir = label_dir

        # 将其整合
        self.path = os.path.join(root_dir, label_dir)

        # os.listdir() 方法用于返回指定的文件夹包含的文件或文件夹的名字的列表。
        self.img_name_path = os.listdir(self.path)

    def __getitem__(self, index):

        img_name = self.img_name_path[index]
        img_item_path = os.path.join(self.path, img_name)
        img = Image.open(img_item_path)

        label = self.label_dir
        # 返回的是图片和名字
        return img, label

    def __len__(self):
        return len(self.img_path)


ants_dataset = MyData('hymenoptera_data/train', 'ants_img')
# for item in ants_dataset.img_path:
#     print(item)
# print(ants_dataset.__len__())
# print(ants_dataset.__getitem__(0))


bees_dataset = MyData('hymenoptera_data/train', 'bees_img')
# print(bees_dataset.__len__())
# print(bees_dataset.__getitem__(0))
#
# print(len(ants_dataset+bees_dataset))

# ant_dataset中包含两个值,一个img一个label
img, label = ants_dataset[0]
img.show()

​ 视频中一开始是先写class的以至于一开始没有弄懂 'root_dir' 和 'label_dir' 是干什么的,在创建实例之后进行传参就可以很好的理解了,前者是指文件夹的路径,后者是文件夹下的分类,由于文件夹下面分别有两个类别的例子,所以分为root和label两类。

dataset提供了访问和处理大量自然语言处理(NLP)数据集的工具,简单来说就是对数据集中的图片进行操作的一个简单的库。

python 复制代码
 def __init__(self, root_dir, label_dir):

        # root_dir = "hymenoptera_data/train"
        # label_dir = "ants_img"
        # 这两个值是由后面的实例传递过来的
        self.root_dir = root_dir
        self.label_dir = label_dir

        # 将其整合
        self.path = os.path.join(root_dir, label_dir)

        # os.listdir() 方法用于返回指定的文件夹包含的文件或文件夹的名字的列表。
        self.img_name_path = os.listdir(self.path)

​ 上述代码中从上到下来看,首先是MyData库,其继承了Dataset这个类,第一个函数就是对数据的初始化,可以理解成java中的构造器一样的功能。

​ os.path.join()此函数是将路径整合在一起赋值给self.path

​ os.listdir()此函数是返回self.path路径下包含的文件夹或文件夹的名字的列表,重点是它返回的是一个列表,这个列表中包含了文件夹下面的文件的信息

python 复制代码
    def __getitem__(self, index):

        img_name = self.img_name_path[index]
        img_item_path = os.path.join(self.path, img_name)
        img = Image.open(img_item_path)

        label = self.label_dir
        # 返回的是图片和名字
        return img, label

    def __len__(self):
        return len(self.img_path)

​ getitem这个函数的功能主要是对列表中的图片信息进行整合和赋值

相关推荐
周杰伦_Jay2 分钟前
简洁明了:介绍大模型的基本概念(大模型和小模型、模型分类、发展历程、泛化和微调)
人工智能·算法·机器学习·生成对抗网络·分类·数据挖掘·transformer
SpikeKing4 分钟前
LLM - 大模型 ScallingLaws 的指导模型设计与实验环境(PLM) 教程(4)
人工智能·llm·transformer·plm·scalinglaws
阿俊仔(摸鱼版)4 分钟前
Python 常用运维模块之Shutil 模块
linux·服务器·python·自动化·云服务器
MarsBighead6 分钟前
(二)PosrgreSQL: Python3 连接Pgvector出错排查
python·postgresql·向量数据库·pgvector
编码浪子13 分钟前
Transformer的编码机制
人工智能·深度学习·transformer
深蓝海拓27 分钟前
Pyside6(PyQT5)中的QTableView与QSqlQueryModel、QSqlTableModel的联合使用
数据库·python·qt·pyqt
IE0627 分钟前
深度学习系列76:流式tts的一个简单实现
人工智能·深度学习
GIS数据转换器31 分钟前
城市生命线安全保障:技术应用与策略创新
大数据·人工智能·安全·3d·智慧城市
无须logic ᭄34 分钟前
CrypTen项目实践
python·机器学习·密码学·同态加密
Channing Lewis1 小时前
flask常见问答题
后端·python·flask