创建tfrecords
import tensorflow as tf
import numpy as np
tfrecords_filename = './data/train.tfrecords'
writer = tf.python_io.TFRecordWriter(tfrecords_filename)
for i in range(100):
img_raw = np.random.random_integers(0,255,size=(7,30))
img_raw = img_raw.tostring()
example = tf.train.Example(features=tf.train.Features(
feature={
'label': tf.train.Feature(float_list = tf.train.FloatList(value=[i])),
'img_raw':tf.train.Feature(bytes_list = tf.train.BytesList(value=[img_raw]))
}))
writer.write(example.SerializeToString())
print(i)
writer.close()
读取tfrecords
import tensorflow as tf
if __name__=='__main__':
tfrecords_filename = "./data/train.tfrecords"
filename_queue = tf.train.string_input_producer([tfrecords_filename],)
reader = tf.TFRecordReader()
_, serialized_example = reader.read(filename_queue)
features = tf.parse_single_example(serialized_example,
features={
'label': tf.FixedLenFeature([], tf.float32),
'img_raw' : tf.FixedLenFeature([], tf.string),
})
image = tf.decode_raw(features['img_raw'],tf.int64)
image = tf.reshape(image, [7,30])
label = tf.cast(features['label'], tf.float32)
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(3):
example, l = sess.run([image,label])
print(example, l)
coord.request_stop()
coord.join(threads)