tfrecord构建自己的数据集

2024-04-03 01:48
文章标签 数据 构建 tfrecord

本文主要是介绍tfrecord构建自己的数据集,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

根据tfrecord构建本地自己的数据集

套话:TFRecord文件中的数据都是通过tf.train.Example Protocol Buffer的格式存储的。其中包含一个从属性名到取值的字典,属性的取值可以为字符串(BytesList),实数列表(FloatList)或整数列表(Int64List)。

比如将,将一个图片存为字符串,其label值存为整数。

message Feature{oneof kind{BytesList    bytes_list = 1;BytesList    int64_list = 1;}
}

给出代码:

我定义的 Feature包含三个字段:

message Feature{oneof kind{BytesList    bytes_list = 1; // 图片值BytesList    int64_list = 1;  // labelBytesList    bytes_list = 1; // 图片的名称}
}

代码:

#encoding:utf-8
import tensorflow as tf 
import numpy as np
import os
def _int64_feature(label):return tf.train.Feature(int64_list=tf.train.Int64List(value=[label])) def _byte_feature(value):return tf.train.Feature(bytes_list=tf.train.BytesList(value=[value])) #指定使用显卡0
os.environ["CUDA_VISIBLE_DEVICES"] = '0'
#图像文件的路径
image_path = '/home/ccf/data/v2/256/0/train/image/'
#设置tfrecord输出目录
out_path = '/home/ccf/'
name ='test2''''
将文件路径和标签放在list中
'''
def get_image_path_label(image_path,label_path):image=[]label=[]for one_path in  os.listdir(image_path):		image.append(image_path+one_path)label.append(one_path.split('_')[0]) return image,label'''
image_path:图片路径,list
labels: 图片标签,list 
save_dir:tfrecord保存路径
name: 保存名称
'''
def convert_to_tfrecord(images,labels,save_dir,name):#创建一个writer来写tfrecordwriter = tf.python_io.TFRecordWriter(save_dir+name+'.tfrecords')with tf.Session() as sess:for i in  range(len(images)):			  #读取图片并编码image_raw_data = tf.gfile.FastGFile(images[i],'rb').read()#若是jpeg格式的图片,换为tf.decode_jpeg(image_raw_data)image_data = tf.image.decode_png(image_raw_data)label = int(labels[i])print(images[i].encode())example = tf.train.Example(features = tf.train.Features(feature= {'label':_int64_feature(label),'name':_byte_feature(images[i].encode()),'image_raw':_byte_feature(image_data.eval().tostring())}))#写入writer.write(example.SerializeToString())if(i>10):breakprint(images[i],i)writer.close()print('writer done')def read_from_tfrecord(tfrecord_path):#创建一个队列从tfrecord中读取数据file_queue = tf.train.string_input_producer([tfrecord_path])reader = tf.TFRecordReader()_,serilazed_example = reader.read(file_queue)image_features = tf.parse_single_example(serilazed_example,features ={'label':tf.FixedLenFeature([],tf.int64),'name':tf.FixedLenFeature([],tf.string),'image_raw':tf.FixedLenFeature([],tf.string)})image = image_features['image_raw']label = image_features['label']image_name = image_features['name']decode_image = tf.decode_raw(image,tf.uint8)reshape_image = tf.reshape(decode_image,[256,256,3])init = tf.initialize_all_variables()with tf.Session() as sess:sess.run(init)#启动多线程处理输入数据coord = tf.train.Coordinator()threads = tf.train.start_queue_runners(sess=sess,coord=coord)for i in range(10):images,labels,image_names = sess.run(image,label,image_name)print(image_names)coord.request_stop()coord.join(threads)
if __name__ == '__main__':images,labels = get_image_path_label(image_path,image_path)  convert_to_tfrecord(images,labels,out_path,name)   //写入tfrecordread_from_tfrecord('/home/ccf/test2.tfrecords')  //读取tfrecord



这篇关于tfrecord构建自己的数据集的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/871619

相关文章

SpringBoot实现接口数据加解密的三种实战方案

《SpringBoot实现接口数据加解密的三种实战方案》在金融支付、用户隐私信息传输等场景中,接口数据若以明文传输,极易被中间人攻击窃取,SpringBoot提供了多种优雅的加解密实现方案,本文将从原... 目录一、为什么需要接口数据加解密?二、核心加解密算法选择1. 对称加密(AES)2. 非对称加密(R

详解如何在SpringBoot控制器中处理用户数据

《详解如何在SpringBoot控制器中处理用户数据》在SpringBoot应用开发中,控制器(Controller)扮演着至关重要的角色,它负责接收用户请求、处理数据并返回响应,本文将深入浅出地讲解... 目录一、获取请求参数1.1 获取查询参数1.2 获取路径参数二、处理表单提交2.1 处理表单数据三、

Spring Validation中9个数据校验工具使用指南

《SpringValidation中9个数据校验工具使用指南》SpringValidation作为Spring生态系统的重要组成部分,提供了一套强大而灵活的数据校验机制,本文给大家介绍了Spring... 目录1. Bean Validation基础注解常用注解示例在控制器中应用2. 自定义约束验证器定义自

C#实现高性能Excel百万数据导出优化实战指南

《C#实现高性能Excel百万数据导出优化实战指南》在日常工作中,Excel数据导出是一个常见的需求,然而,当数据量较大时,性能和内存问题往往会成为限制导出效率的瓶颈,下面我们看看C#如何结合EPPl... 目录一、技术方案核心对比二、各方案选型建议三、性能对比数据四、核心代码实现1. MiniExcel

Python+wxPython构建图像编辑器

《Python+wxPython构建图像编辑器》图像编辑应用是学习GUI编程和图像处理的绝佳项目,本教程中,我们将使用wxPython,一个跨平台的PythonGUI工具包,构建一个简单的... 目录引言环境设置创建主窗口加载和显示图像实现绘制工具矩形绘制箭头绘制文字绘制临时绘制处理缩放和旋转缩放旋转保存编

SQL常用操作精华之复制表、跨库查询、删除重复数据

《SQL常用操作精华之复制表、跨库查询、删除重复数据》:本文主要介绍SQL常用操作精华之复制表、跨库查询、删除重复数据,这些SQL操作涵盖了数据库开发中最常用的技术点,包括表操作、数据查询、数据管... 目录SQL常用操作精华总结表结构与数据操作高级查询技巧SQL常用操作精华总结表结构与数据操作复制表结

Redis中的数据一致性问题以及解决方案

《Redis中的数据一致性问题以及解决方案》:本文主要介绍Redis中的数据一致性问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Redis 数据一致性问题的产生1. 单节点环境的一致性问题2. 网络分区和宕机3. 并发写入导致的脏数据4. 持

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St