由浅入深之Tensorflow(3)----数据读取之TFRecords

转载自http://blog.csdn.net/u012759136/article/details/52232266 原文作者github地址

概述

关于Tensorflow读取数据,官网给出了三种方法:

  • 供给数据(Feeding): 在TensorFlow程序运行的每一步, 让Python代码来供给数据。
  • 从文件读取数据: 在TensorFlow图的起始, 让一个输入管线从文件中读取数据。
  • 预加载数据: 在TensorFlow图中定义常量或变量来保存所有数据(仅适用于数据量比较小的情况)。

对于数据量较小而言,可能一般选择直接将数据加载进内存,然后再分batch输入网络进行训练(tip:使用这种方法时,结合yield 使用更为简洁,大家自己尝试一下吧,我就不赘述了)。但是,如果数据量较大,这样的方法就不适用了,因为太耗内存,所以这时最好使用tensorflow提供的队列queue,也就是第二种方法 从文件读取数据。对于一些特定的读取,比如csv文件格式,官网有相关的描述,在这儿我介绍一种比较通用,高效的读取方法(官网介绍的少),即使用tensorflow内定标准格式——TFRecords

TFRecords

TFRecords其实是一种二进制文件,虽然它不如其他格式好理解,但是它能更好的利用内存,更方便复制和移动,并且不需要单独的标签文件(等会儿就知道为什么了)… …总而言之,这样的文件格式好处多多,所以让我们用起来吧。

TFRecords文件包含了tf.train.Example 协议内存块(protocol buffer)(协议内存块包含了字段 Features)。我们可以写一段代码获取你的数据, 将数据填入到Example协议内存块(protocol buffer),将协议内存块序列化为一个字符串, 并且通过tf.python_io.TFRecordWriter 写入到TFRecords文件。

从TFRecords文件中读取数据, 可以使用tf.TFRecordReadertf.parse_single_example解析器。这个操作可以将Example协议内存块(protocol buffer)解析为张量。

接下来,让我们开始读取数据之旅吧~

生成TFRecords文件

我们使用tf.train.Example来定义我们要填入的数据格式,然后使用tf.python_io.TFRecordWriter来写入。

import os
import tensorflow as tf
from PIL import Imagecwd = os.getcwd()'''
此处我加载的数据目录如下:
0 -- img1.jpgimg2.jpgimg3.jpg...
1 -- img1.jpgimg2.jpg...
2 -- ...
...
'''
writer = tf.python_io.TFRecordWriter("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_nameimg = Image.open(img_path)img = img.resize((224, 224))img_raw = img.tobytes()              #将图片转化为原生bytesexample = 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]))}))writer.write(example.SerializeToString())  #序列化为字符串
writer.close()

关于Example Feature的相关定义和详细内容,我推荐去官网查看相关API。

基本的,一个Example中包含FeaturesFeatures里包含Feature(这里没s)的字典。最后,Feature里包含有一个 FloatList, 或者ByteList,或者Int64List

就这样,我们把相关的信息都存到了一个文件中,所以前面才说不用单独的label文件。而且读取也很方便。

for serialized_example in tf.python_io.tf_record_iterator("train.tfrecords"):example = tf.train.Example()example.ParseFromString(serialized_example)image = example.features.feature['image'].bytes_list.valuelabel = example.features.feature['label'].int64_list.value# 可以做一些预处理之类的print image, label

使用队列读取

一旦生成了TFRecords文件,接下来就可以使用队列(queue)读取数据了。

def read_and_decode(filename):#根据文件名生成一个队列filename_queue = tf.train.string_input_producer([filename])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),})img = tf.decode_raw(features['img_raw'], tf.uint8)img = tf.reshape(img, [224, 224, 3])img = tf.cast(img, tf.float32) * (1. / 255) - 0.5label = tf.cast(features['label'], tf.int32)return img, label

之后我们可以在训练的时候这样使用

img, label = read_and_decode("train.tfrecords")#使用shuffle_batch可以随机打乱输入
img_batch, label_batch = tf.train.shuffle_batch([img, label],batch_size=30, capacity=2000,min_after_dequeue=1000)
init = tf.initialize_all_variables()with tf.Session() as sess:sess.run(init)threads = tf.train.start_queue_runners(sess=sess)for i in range(3):val, l= sess.run([img_batch, label_batch])#我们也可以根据需要对val, l进行处理#l = to_categorical(l, 12) print(val.shape, l)

至此,tensorflow高效从文件读取数据差不多完结了。

恩?等等…什么叫差不多?对了,还有几个注意事项:

第一,tensorflow里的graph能够记住状态(state),这使得TFRecordReader能够记住tfrecord的位置,并且始终能返回下一个。而这就要求我们在使用之前,必须初始化整个graph,这里我们使用了函数tf.initialize_all_variables()来进行初始化。

第二,tensorflow中的队列和普通的队列差不多,不过它里面的operationtensor都是符号型的(symbolic),在调用sess.run()时才执行。

第三, TFRecordReader会一直弹出队列中文件的名字,直到队列为空。


总结

  1. 生成tfrecord文件
  2. 定义record reader解析tfrecord文件
  3. 构造一个批生成器(batcher
  4. 构建其他的操作
  5. 初始化所有的操作
  6. 启动QueueRunner
浅闻陋见,还望指正

由浅入深之Tensorflow(3)----数据读取之TFRecords相关推荐

  1. tensorflow 标准数据读取 tfrecords

    TensorFlow提供了一种TFRecords的格式来统一存储数据.理论上,TFRecords可以存储任何形式的数据 , TFRecords文件的是以tf.train.Example Protoco ...

  2. TensorFlow——二进制数据读取

    一.CIFAR10二进制数据集介绍 https://www.cs.toronto.edu/~kriz/cifar.html 二进制版本数据文件 二进制版本包含文件data_batch_1.bin,da ...

  3. 『TensorFlow』数据读取类_data.Dataset

    一.资料 参考原文: TensorFlow全新的数据读取方式:Dataset API入门教程 API接口简介: TensorFlow的数据集 二.背景 注意,在TensorFlow 1.3中,Data ...

  4. tensorflow的数据读取 tf.data.DataSet、tf.data.Iterator

    tensorflow的工程有使用python的多进程读取数据,然后给feed给神经网络进行训练. 也有tensorflow中的 tf.data.DataSet的使用.并且由于是tensorflow框架 ...

  5. TensorFlow中数据读取—如何载入样本

    考虑到要是自己去做一个项目,那么第一步是如何把数据导入到代码中,何种形式呢?是否需要做预处理?官网中给的实例mnist,数据导入都是写好的模块,那么自己的数据呢? 一.从文件中读取数据(CSV文件.二 ...

  6. linux 读取大量图片 内存,10 张图帮你搞定 TensorFlow 数据读取机制

    导读 在学习tensorflow的过程中,有很多小伙伴反映读取数据这一块很难理解.确实这一块官方的教程比较简略,网上也找不到什么合适的学习材料.今天这篇文章就以图片的形式,用最简单的语言,为大家详细解 ...

  7. tensorflow 1.0 学习:十图详解tensorflow数据读取机制

    本文转自:https://zhuanlan.zhihu.com/p/27238630 在学习tensorflow的过程中,有很多小伙伴反映读取数据这一块很难理解.确实这一块官方的教程比较简略,网上也找 ...

  8. 十图详解TensorFlow数据读取机制(附代码)

    在学习TensorFlow的过程中,有很多小伙伴反映读取数据这一块很难理解.确实这一块官方的教程比较简略,网上也找不到什么合适的学习材料.今天这篇文章就以图片的形式,用最简单的语言,为大家详细解释一下 ...

  9. TensorFlow学习笔记(二十二) tensorflow数据读取方法总结

    本文PDF文件下载地址:http://download.csdn.net/download/qq_36330643/9938438 Tensorflow的数据读取有三种方式: 1. Preloaded ...

最新文章

  1. 每日一题(合并表格)
  2. layui设置按钮不可点击_(eblog)7、博客发布收藏、用户中心的设置
  3. 01_Eclipse的使用方法
  4. 前端学习(2882):实现视图初始化
  5. php 函数封装上传,PHP(多)文件上传实现和函数封装
  6. HTML中光移动边框,CSS 边框各边
  7. SQL error: cannot use the special principal 'sa'
  8. 企业级软件协作,没有数据怎么人工智能?
  9. 【SSH】 之 Struts2
  10. sql server 查询数据库所有的表名+字段
  11. 2021软考网络工程师2004-2020年真题含答案解析(最新)
  12. 【js】pagination分页(支持首页,末页,跳转)
  13. html文件中flash视频格式(flv、swf)文件的嵌入方法
  14. dell5580bios恢复出厂_如何进入戴尔笔记本bios及恢复bios出厂设置
  15. html id命名规范,CSS常用类/ID命名规范
  16. 0704最简单的驱动hello
  17. CSS3之多列布局columns学习
  18. java过滤特殊字符,只留下字母、数字和汉字
  19. 分数类中的运算符重载(续)
  20. TinyPng图片压缩的正确打开方式

热门文章

  1. centos 安装2个mysql_CentOs服务器下安装两个个MySql数据库踩坑日记
  2. xxl-job 执行结果是空_空指针,段错误,这场面试我栽倒在这里了!
  3. android 新分区 挂载,android 新增分区以及挂载方法-Go语言中文社区
  4. node mysql批量写入_如何使用node.js在MySQL中进行批量插入
  5. 实现pv uv统计_程序员修仙之路优雅快速的统计千万级别uv
  6. r 多元有序logistic回归_R语言多元Logistic逻辑回归 应用案例
  7. 皮一皮:是亲爹的操作 ,没错...
  8. 每日一皮:据说现在小孩从小容易生病、体质不如从前是因为少了这个运动......
  9. 7月平均工资下来,Java程序员哭笑不得!
  10. 【译】Spring官方教程:使用STS的入门指南