这篇文章是在上班摸鱼的时候随手整理的一些常用CV数据集(文末附带我处理好的数据的下载资源)

众所周知,通过使用Torchvision,可以方便快捷地加载一些较为常用的数据集。但是(敲黑板!)如果本地没有已下载好的数据集,就需要看着torchvision用堪比乌龟的速度从网上下载,甚至还有可能经常下载失败;即使本地有已经下载好的数据集,还需要进函数源代码修改地址,才能顺利地加载数据。所以我想试试能不能把所有已处理的数据集直接下载并整合好,到时候如果要用的话能够直接调用。

废话不多说,直接开始!

1.Torchvision.datasets的“正确”打开方式

以 “梦开始的地方” :MNIST数据集为例

使用torchvision加载MNIST数据集的方法如下所示:

import torchvision

Train_datasets_MNIST = torchvision.datasets.MNIST(
root = './data', #这里是要下载的数据集的位置
train = True, #Train=True即下载训练集,否则下载的就是测试集
transform = torchvision.transforms.ToTensor(), #将图片转化为取值[0,1]的Tensor
download = True #download为true,意思就是需要下载数据集
)

如果本地没有MNIST数据集,我们就需要将download设置为"True",以此让MNIST函数从官方地址下载数据,但是由于诸多的不可抗力影响,下载的过程可能不会太过顺利。像MNIST这样比较小的数据集可能不会出问题,但是遇到大一点的可能就会下载失败。

然而,就算是事先将.gz压缩包下好,放在要求的目录下,也会出现datasets函数无法识别数据集的情况。具体报错可以参考这位小伙伴的知乎帖子:

使用torchvision下载MINIST及配置踩坑笔记 - 知乎 (zhihu.com)

当然,这篇帖子中提供了一个很棒的解决方法,前排感谢大佬!!!

但我还是觉得每次都进函数改源代码很麻烦。

于是我自己在Colab上尝试将数据集全都下载好,放到一个名叫"data"的文件夹中,接下来每次使用的时候都只需要将root设置为“data”的路径,这样就可以直接加载。

2.我的数据集处理步骤

首先,我在Colab中按照正确的食用方式,将一些比较常用的数据集下好,放到一个统一的文件夹内(还是以MNIST数据集为例):

首先我们还是执行下面的代码:

import torchvision

Train_datasets_MNIST = torchvision.datasets.MNIST(
root = './data', #这里是要下载的数据集的位置
train = True, #Train=True即下载训练集,否则下载的就是测试集
transform = torchvision.transforms.ToTensor(), #将图片转化为取值[0,1]的Tensor
download = True #download为true,意思就是需要下载数据集
)

然后会显示:

Downloading http://codh.rois.ac.jp/kmnist/dataset/kmnist/train-images-idx3-ubyte.gz
Downloading http://codh.rois.ac.jp/kmnist/dataset/kmnist/train-images-idx3-ubyte.gz to ./data/KMNIST/raw/train-images-idx3-ubyte.gz
18165760/? [00:08<00:00, 2444994.38it/s]
Extracting ./data/KMNIST/raw/train-images-idx3-ubyte.gz to ./data/KMNIST/raw Downloading http://codh.rois.ac.jp/kmnist/dataset/kmnist/train-labels-idx1-ubyte.gz
Downloading http://codh.rois.ac.jp/kmnist/dataset/kmnist/train-labels-idx1-ubyte.gz to ./data/KMNIST/raw/train-labels-idx1-ubyte.gz
29696/? [00:00<00:00, 332857.78it/s]
Extracting ./data/KMNIST/raw/train-labels-idx1-ubyte.gz to ./data/KMNIST/raw Downloading http://codh.rois.ac.jp/kmnist/dataset/kmnist/t10k-images-idx3-ubyte.gz
Downloading http://codh.rois.ac.jp/kmnist/dataset/kmnist/t10k-images-idx3-ubyte.gz to ./data/KMNIST/raw/t10k-images-idx3-ubyte.gz
3041280/? [00:01<00:00, 2025372.47it/s]
Extracting ./data/KMNIST/raw/t10k-images-idx3-ubyte.gz to ./data/KMNIST/raw Downloading http://codh.rois.ac.jp/kmnist/dataset/kmnist/t10k-labels-idx1-ubyte.gz
Downloading http://codh.rois.ac.jp/kmnist/dataset/kmnist/t10k-labels-idx1-ubyte.gz to ./data/KMNIST/raw/t10k-labels-idx1-ubyte.gz
100%
5120/5120 [00:00<00:00, 139460.57it/s]
Extracting ./data/KMNIST/raw/t10k-labels-idx1-ubyte.gz to ./data/KMNIST/raw

这里我们就下载成功了。然后我把data文件夹换了个位置,并且在新的位置下运行:

Train_datasets_MNIST = torchvision.datasets.MNIST(
root = './data', #这里是要下载的数据集的位置
train = True, #Train=True即下载训练集,否则下载的就是测试集
transform = torchvision.transforms.ToTensor(), #将图片转化为取值[0,1]的Tensor
download = False #这里download为False,意思就是加载本地数据集
)

运行成功,没有报错(亲测有效)。

最后我把包含MNIST,KMNIST,CIFAR10,CIFAR100等较为常用的数据集的data文件夹打包为一个压缩包,并命名为Demo.zip:

!zip -r Demo.zip data

3.整合包食用方法

下载完整合包之后,选择一个地址解压,就能看到其中的“data”文件夹。

然后我们每次加载数据的时候,只需要将datasets函数中的参数 "root" ,设置为data文件夹即可,就可以直接加载数据,不需要额外下载或者修改函数代码。

例如,我将data文件夹放在了桌面,并且我想加载data文件夹下的MNIST数据集,就只需要直接调用datasets下的MNIST函数,然后将root这一参数设置为data所在的位置。

#文件下载地址下班之后贴在这里

Torchvision datasets中的经典数据集梳理(以及与OCR相关的常用数据集整理)的更多相关文章

  1. Java中的经典算法之冒泡排序(Bubble Sort)

    Java中的经典算法之冒泡排序(Bubble Sort) 神话丿小王子的博客主页 原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一 ...

  2. Java中的经典算法之选择排序(SelectionSort)

    Java中的经典算法之选择排序(SelectionSort) 神话丿小王子的博客主页 a) 原理:每一趟从待排序的记录中选出最小的元素,顺序放在已排好序的序列最后,直到全部记录排序完毕.也就是:每一趟 ...

  3. C语言中的经典例题用javascript怎么解?(一)

    C语言中的经典例题用javascript怎么解?(一) 一.1+2+3+……+100=?        <script type="text/javascript">  ...

  4. MATLAB对于文本文件(txt)数据读取的技巧总结(经典中的经典)

    振动论坛原版主eight的经典贴http://www.chinavib.com/thread-45622-1-1.html MATLAB对于文本文件(txt)进行数据读取的技巧总结(经典中的经典)由于 ...

  5. 如何在ubuntu 12.04 中安装经典的 GNOME桌面

    这次介绍的是如何在ubuntu 12.04 中安装经典的 GNOME桌面,默认的 Ubuntu 12.04 默认unity桌面,一些用户不喜欢 Unity 桌面,所以想找回昔日的经典Gnome桌面. ...

  6. CNN中的经典结构之AlexNet

    AlexNet的基本结构 Alexnet是由5个卷积层和三个全连接层组成,一共8个权重层(池化层不是权重层因为其没有参数),其中ReLU激活函数作用在每个卷积层和全连接层上,在第一个卷积层和第二个卷积 ...

  7. Linux 运维工作中的经典应用ansible(批量管理)Docker容器技术(环境的快速搭建)

    一 Ansible自动化运维工具 Python 在运维工作中的经典应用 ansible(批量管理操作) .安装ansible(需要bese epel 2种源) wget -O /etc/yum.rep ...

  8. 从图像中检测和识别表格,北航&微软提出新型数据集 TableBank

    纯学术 的识别表格的文章: http://hrb-br.com/5007404/20190321A0B99Y00.html https://github.com/doc-analysis/TableB ...

  9. 如何在 Azure 中的经典 Windows 虚拟机上设置终结点

    在 Azure 中使用经典部署模型创建的所有 Windows 虚拟机都可以通过专用网络通道与同一云服务或虚拟网络中的其他虚拟机自动通信. 但是,Internet 或其他虚拟网络中的计算机需要终结点将入 ...

  10. A+B Problem——经典中的经典

    A+B Problem,这道题,吸收了天地的精华,是当之无愧的经典中的经典中的经典.自古以来OIer都会经过它的历练(这不是白说吗?),下面就有我herobrine来讲讲这道题的各种做法. 好吧,同志 ...

随机推荐

  1. 解决WIN7下pl/sql连接弹出空白提示框问题

    问题描述: win7 32位系统,已安装oracle10.0开发客户端,已配置数据库, 登陆pl/sql时出现空白提示框问题,尝试重装oracle无果,于是上网查找解决方法,逐步尝试,终于把客户端弄好 ...

  2. 【NAS使用心得】使用Synology Photos管理照片

    整理方式 1.本地没有整理或只按年份整理的:时间线模式下直接上传,让软件自己按照片创建时间生成文件夹:有按年份生成相册需求的,可以用"选择照片以创建相册"功能,找到年份文件夹,全选 ...

  3. centos7中Firefox安装Flash插件

    第一步:先下载好Flash插件安装包,可以到Adobe官网下载.因为是linux 64位系统,所以要下个匹配的,我下载的是flash_player_npapi_linux.x86_64.tar.gz, ...

  4. Sql Server代理作业、定时任务

    需求: 本次需求为每15分钟获取一次思路为,创建结果表,代理作业定时更新数据并存入结果表,后端只需要调用结果表数据数据,如果超期不同的天数则给出不同的提示信息,因为没有触发点,所以用到了本文内容. 右 ...

  5. scrapy.Request callback不执行

    1.在scrapy.Request方法里边加上参数dont_filter=True(去重) 2.增加是不是allowed_domains范围内的url 3.yield Request 改为yield ...

  6. tornado cgi wsgi uwsgi之间的关系

    Tornado可以当作HTTP server,直接TCP开始实现HTTP服务,这也就是为啥说Tornado可以不经过WSGI.实际上它也不是CGI. CGI是指通过stdin和stdout进行HTTP ...

  7. DVWA-XSS (Stored) 存储型XSS

    存储型XSS,顾名思义,就是会传入数据库,长久的使用,常见为留言板,用户信息资料. LOW 审计源码 <?php // 是否提交 btnSign if( isset( $_POST[ 'btnS ...

  8. c++ 内存顺序

    搞懂无锁编程的重要一步是完全理解内存顺序! 本教程由作者和ChatGPT通力合作完成. 都有哪几种? c++的内存模型共有6种 memory_order_relaxed memory_order_co ...

  9. 网络调试助手|网络调试助手(CM精装版) V4.1.0 绿色版

    http://www.winwin7.com/soft/16987.html#xiazai 网络调试助手软件功能 1.支持UDP,TCP协议2.支持单播/广播,集成TCP服务器和客户端3.支持ASCI ...

  10. 开源不到 48 小时获 35k star 的推荐算法「GitHub 热点速览」

    本周的热点除了 GPT 各类衍生品之外,还多了一个被马斯克预告过.在愚人节开源出来的推特推荐算法,开源不到 2 天就有了 35k+ 的 star,有意思的是,除了推荐算法本身之外,阅读源码的工程师们甚 ...