官网的mnist和cifar10数据之后,笔者尝试着制作自己的数据集,并保存,读入,显示。 TensorFlow可以支持cifar10的数据格式, 也提供了标准的TFRecord 格式,而关于 tensorflow 读取数据, 官网提供了3中方法 
1 Feeding: 在tensorflow程序运行的每一步, 用Python代码在线提供数据 
2 Reader : 在一个计算图(tf.graph)的开始前,将文件读入到流(queue)中 
3 在声明tf.variable变量或numpy数组时保存数据。受限于内存大小,适用于数据较小的情况

在本文,主要介绍第二种方法,利用tf.record标准接口来读入文件

准备图片数据

笔者找了2类狗的图片, 哈士奇和吉娃娃, 全部 resize成128 * 128大小 
如下图, 保存地址为/home/molys/Python/data/dog 
 
每类中有10张图片 
 

现在利用这2 类 20张图片制作TFRecord文件

制作TFRECORD文件

1 先聊一下tfrecord, 这是一种将图像数据和标签放在一起的二进制文件,能更好的利用内存,在tensorflow中快速的复制,移动,读取,存储 等等..

这里注意,tfrecord会根据你选择输入文件的类,自动给每一类打上同样的标签 
如在本例中,只有0,1 两类

2 先上“制作TFRecord文件”的代码,注释附详解


import os
import tensorflow as tf
from PIL import Image  #注意Image,后面会用到
import matplotlib.pyplot as plt
import numpy as npcwd='/home/molys/Python/data/'
classes={'husky','chihuahua'} #人为 设定 2 类
writer= tf.python_io.TFRecordWriter("dog_train.tfrecords") #要生成的文件for index,name in enumerate(classes):class_path=cwd+name+'/'for img_name in os.listdir(class_path): img_path=class_path+img_name #每一个图片的地址img=Image.open(img_path)img= img.resize((128,128))img_raw=img.tobytes()#将图片转化为二进制格式example = tf.train.Example(features=tf.train.Features(feature={"label": tf.train.Feature(int64_list=tf.train.Int64List(value=[index])),'img_raw': tf.train.Feature(bytes_list=tf.train.BytesList(value=[img_raw]))})) #example对象对label和image数据进行封装writer.write(example.SerializeToString())  #序列化为字符串writer.close()

运行完这段代码后,会生成dog_train.tfrecords 文件,如下图 

tf.train.Example 协议内存块包含了Features字段,通过feature将图片的二进制数据和label进行统一封装, 然后将example协议内存块转化为字符串, tf.python_io.TFRecordWriter 写入到TFRecords文件中。

读取TFRECORD文件

在制作完tfrecord文件后, 将该文件读入到数据流中。 
代码如下


def read_and_decode(filename): # 读入dog_train.tfrecordsfilename_queue = tf.train.string_input_producer([filename])#生成一个queue队列reader = tf.TFRecordReader()_, serialized_example = reader.read(filename_queue)#返回文件名和文件features = tf.parse_single_example(serialized_example,features={'label': tf.FixedLenFeature([], tf.int64),'img_raw' : tf.FixedLenFeature([], tf.string),})#将image数据和label取出来img = tf.decode_raw(features['img_raw'], tf.uint8)img = tf.reshape(img, [128, 128, 3])  #reshape为128*128的3通道图片img = tf.cast(img, tf.float32) * (1. / 255) - 0.5 #在流中抛出img张量label = tf.cast(features['label'], tf.int32) #在流中抛出label张量return img, label

注意,feature的属性“label”和“img_raw”名称要和制作时统一 ,返回的img数据和label数据一一对应。返回的img和label是2个 tf 张量,print出来 如下图 

显示tfrecord格式的图片

有些时候我们希望检查分类是否有误,或者在之后的网络训练过程中可以监视,输出图片,来观察分类等操作的结果,那么我们就可以session回话中,将tfrecord的图片从流中读取出来,再保存。 紧跟着一开始的代码写:


filename_queue = tf.train.string_input_producer(["dog_train.tfrecords"]) #读入流中
reader = tf.TFRecordReader()
_, serialized_example = reader.read(filename_queue)   #返回文件名和文件
features = tf.parse_single_example(serialized_example,features={'label': tf.FixedLenFeature([], tf.int64),'img_raw' : tf.FixedLenFeature([], tf.string),})  #取出包含image和label的feature对象
image = tf.decode_raw(features['img_raw'], tf.uint8)
image = tf.reshape(image, [128, 128, 3])
label = tf.cast(features['label'], tf.int32)
with tf.Session() as sess: #开始一个会话init_op = tf.initialize_all_variables()sess.run(init_op)coord=tf.train.Coordinator()threads= tf.train.start_queue_runners(coord=coord)for i in range(20):example, l = sess.run([image,label])#在会话中取出image和labelimg=Image.fromarray(example, 'RGB')#这里Image是之前提到的img.save(cwd+str(i)+'_''Label_'+str(l)+'.jpg')#存下图片print(example, l)coord.request_stop()coord.join(threads)

代码运行完后, 从tfrecord中取出的文件被保存了。如下图: 

在这里我们可以看到,图片文件名的第一个数字表示在流中的顺序(笔者这里没有用shuffle), 第二个数字则是 每个图片的label,吉娃娃都为0,哈士奇都为1。 由此可见,我们一开始制作tfrecord文件时,图片分类正确。

如有问题请留言,博主不定期更新。感觉有帮助的话,请赞一个 (。・`ω´・)

TensorFlow 制作自己的TFRecord数据集相关推荐

  1. TensorFlow 制作自己的TFRecord数据集

    TensorFlow 制作自己的TFRecord数据集 准备图片数据 网上下载了2类吉他和房子的图片, 全部 resize成64*64大小 如下图, 保存项目下: 现在利用这2 类 共108张图片制作 ...

  2. Tensorflow—tfrecord数据集生成与使用

    参考内容: 数据读取的官方教程:Tensorflow导入数据以及使用数据 tfrecord数据集生成: 数据准备:图片数据+图片目录与label一一对应的的txt 先读取图片信息的txt文件,得到每个 ...

  3. 用Tensorflow处理自己的数据:制作自己的TFRecords数据集

    转载请注明作者和出处: http://blog.csdn.net/wiinter_fdd/article/details/72835939 运行平台: Windows Python版本: Python ...

  4. Tensorflow-制作与使用tfrecord数据集

    引言   本次博文目的是记录下tfrecord数据集的制作与使用方式.(踩了无数坑OTZ)   这里贴上一个数据读取的官方教程:Tensorflow导入数据以及使用数据   接下来举个例子说明怎么用t ...

  5. Tensorflow生成自己的图片数据集TFrecords(支持多标签label)

    Tensorflow生成自己的图片数据集TFrecords 尊重原创,转载请注明出处:https://blog.csdn.net/guyuealian/article/details/80857228 ...

  6. tensorflow yolov3训练自己的数据集,详细教程

    这个教程是我在自己学习的过程中写的,当作一个笔记,写的比较详细 在github上下载yolov3的tensorflow1.0版本: https://github.com/YunYang1994/ten ...

  7. 利用tensorflow训练自己的图片数据集——数据准备

    昨天实现了一个简单的CNN网络.用了MNIST数据集,虽然看来对这个数据集用的很多,但是真正这个数据集是怎么在训练的时候被调用的,以及怎么把它换成自己的数据集都是一脸懵. 直接附上链接:MNIST数据 ...

  8. Tensorflow下用自己的数据集对Faster RCNN进行训练和测试(二)1

    原 Tensorflow下用自己的数据集对Faster RCNN进行训练和测试(二) 2018年08月21日 22:20:38 子季鹰才 阅读数:1811 对于Tensorflow版本的Faster ...

  9. 从零开始制作人脸表情的数据集

    一.背景 人脸表情识别网上已有很多教程,大多基于fer2013数据集展开的.现在的问题就在于fer2013数据集的数量太少,表情的区分度不够明显,大部分基于此数据集的模型,其识别精度仅有70%左右. ...

最新文章

  1. chrono 使用备注
  2. 《javascript模式》 容易踩中的那些坑
  3. u盘可以安装java吗_java下载安装 (三)Java 开发环境配置
  4. Openstack 实现技术分解 (1) 开发环境 — Devstack 部署案例详解
  5. 基于MIPS架构的BackTrace实现
  6. 剑指offer例题——二维数组中的查找
  7. SharePoint 2013 REST 服务使用简介
  8. 编译Python2.7.10
  9. Matlab去掉数组中0
  10. SpringBoot中oauth2.0学习之服务端配置快速上手
  11. 解决在ascx使用outputcache就不可以设置用户控件自己的属性
  12. 使用 Async 和 Await 的异步编程
  13. Elasticsearch的JavaAPI
  14. python安卓下载-QPython下载
  15. 翻书插件:bookblock.js
  16. nginx打开网页报错
  17. 中央电视台最常用的 100 首经典背景乐曲(视频制作音乐推荐) 2009-05-12 17:31:47
  18. wirehark数据分析与取证flag.pcap
  19. React基础(伍)———【案例】todoList
  20. 许久不动笔,,再来点人生感悟吧

热门文章

  1. 可怕!程序员的黑砖窑,码农果真在东南亚被打
  2. linux清除内存buffer,Linux清理Buffer/Cache内存空间让系统变流畅
  3. “当我在荒废时间的时候会有多少人在拼命。”——转自豆瓣
  4. 【学习方法】努力学习没效果?来看看学神的正确姿势!破除假努力,学习效率超级加倍!学神不会告诉你的高效学习方法论!
  5. arcgis serverSOE几何网络分析
  6. 尚医通 (二)项目搭建
  7. redis 管理工具比对
  8. C语言求最大公约数最小公倍数
  9. 从哪里下载OpenJDK
  10. iOS10.3新特性图文介绍