tf创建tfRecord文件

2024-04-20 01:48
文章标签 创建 tf tfrecord

本文主要是介绍tf创建tfRecord文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目详细请猛戳我的github地址,直接可运行:https://github.com/SamXiaosheng/create-tfRecord

下面是main文件代码和create tfRecord文件:

import tensorflow as tf
from tfRecord import *
import cv2FLAGS = tf.app.flags.FLAGStf.app.flags.DEFINE_string('image_dir', './image/',"""Directory where to write event logs """)def main(_):
    create_tfrecords(FLAGS.image_dir)image_batch,label_batch =read_and_decode('test.tfRecord')with tf.Session() as sess:
        coord = tf.train.Coordinator()threads = tf.train.start_queue_runners(sess=sess, coord=coord)while not coord.should_stop():
            image,label = sess.run([image_batch,label_batch])print(label)cv2.imshow('image',image[0])cv2.waitKey(200)coord.request_stop()coord.join(threads)if __name__ == '__main__':
    tf.app.run()


import tensorflow as tf
import numpy as np
import os
import cv2def 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, [227, 227, 3])#img = tf.cast(img, tf.float32) * (1. / 255) - 0.5
    label = tf.cast(features['label'], tf.uint8)image_batch, label_batch = tf.train.shuffle_batch([img, label],batch_size=1,#这里参数设置目的是每次只读取一个样本
                                                    capacity=1,min_after_dequeue=0)#label_batch = tf.one_hot(label_batch, NUM_CLASSES)
    #label_batch = tf.cast(label_batch, dtype=tf.int64)
    #label_batch = tf.reshape(label_batch, [batch_size, NUM_CLASSES])

    return image_batch, label_batch
#读取某目录路径下的所有文件,返回图片的名称列表
def dirtomdfbatchmsra(dirpath):#读取目录下训练图像和对应的label
    image_ext = 'jpg'
    images = [fn for fn in os.listdir(dirpath) if fn.endswith(image_ext)]#返回dirpath路径下所有后缀jpg文件
    images.sort()#排序的目的有利于样本和标签的对应
    #print(images)
    gt_ext = 'png'
    gt_maps = [fn for fn in os.listdir(dirpath) if fn.endswith(gt_ext)]gt_maps.sort()#print(gt_maps)
    return gt_maps,images#返回gt图和训练image的所有文件名

def create_tfrecords(image_dir):
    writer = tf.python_io.TFRecordWriter("test.tfRecord")image_png,image_jpg = dirtomdfbatchmsra(image_dir)for index, name in enumerate(image_jpg):
            img = cv2.imread(image_dir+name).astype(np.uint8)img = cv2.resize(img,(227,227))#统一大小
            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]))}))writer.write(example.SerializeToString())for index, name in enumerate(image_png):
            img = cv2.imread(image_dir+name).astype(np.uint8)img = cv2.resize(img,(227, 227))#
            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]))}))writer.write(example.SerializeToString())writer.close()




这篇关于tf创建tfRecord文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Python创建Excel的4种方式小结

《Python创建Excel的4种方式小结》这篇文章主要为大家详细介绍了Python中创建Excel的4种常见方式,文中的示例代码简洁易懂,具有一定的参考价值,感兴趣的小伙伴可以学习一下... 目录库的安装代码1——pandas代码2——openpyxl代码3——xlsxwriterwww.cppcns.c

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

mysql外键创建不成功/失效如何处理

《mysql外键创建不成功/失效如何处理》文章介绍了在MySQL5.5.40版本中,创建带有外键约束的`stu`和`grade`表时遇到的问题,发现`grade`表的`id`字段没有随着`studen... 当前mysql版本:SELECT VERSION();结果为:5.5.40。在复习mysql外键约

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

Window Server2016 AD域的创建的方法步骤

《WindowServer2016AD域的创建的方法步骤》本文主要介绍了WindowServer2016AD域的创建的方法步骤,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、准备条件二、在ServerA服务器中常见AD域管理器:三、创建AD域,域地址为“test.ly”

Python在固定文件夹批量创建固定后缀的文件(方法详解)

《Python在固定文件夹批量创建固定后缀的文件(方法详解)》文章讲述了如何使用Python批量创建后缀为.md的文件夹,生成100个,代码中需要修改的路径、前缀和后缀名,并提供了注意事项和代码示例,... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果5.

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.