python - 无法在 tensorflow 中成功读取图像

标签 python image machine-learning tensorflow computer-vision

我想批量读取jpeg图像以进行图像识别。图像位于/Image_p/文件中,图像名称列于 label.csv 文件中,如 14634_right 所示。

我的问题是如何修复我的代码以成功将图像批量读取? 更具体地说,我不知道是否应该写一个for循环以及在哪里实现它。

对于原始代码,我在 tf.train.shuffle_batch() 上收到错误消息功能:

ValueError: All shapes must be fully defined: [TensorShape([Dimension(None), Dimension(None), Dimension(3)]), TensorShape([])]

我的原始代码:

# filepath
csv_filepath = r'C:\Users\Jeffy\OneDrive\Course\NMDA\retinaProject\label.csv'

# image parameter
pic_num = 100
pic_height = 64
pic_width = 64
batch_size = 10

# =============================================================================
# import library
import tensorflow as tf
import numpy as np

# =============================================================================
# read csv data
csv = np.loadtxt(open(csv_filepath,"rb"), delimiter=",", dtype='str')
pic_filename = ["" for x in range(pic_num)]

for i in range(pic_num):
    pic_filename[i] = eval(csv[i,0]).decode("utf-8") +'.jpeg'

# read the data into batch
for i in range(pic_num):
    # read and decode the image
    image_contents = tf.read_file('Image_p/' + eval(csv[i,0]).decode("utf-8") +'.jpeg')
    image = tf.image.decode_jpeg(image_contents, channels=3)
    image = tf.to_float(image)

    # Generate batch
    batch = tf.train.shuffle_batch([image, float(eval(csv[i,1]))], 
                                   batch_size = batch_size, 
                                    num_threads = 1,

                                    capacity = batch_size * 100, 
                                    min_after_dequeue = batch_size * 10)


with tf.Session() as sess:    
    sess.run(tf.global_variables_initializer())

    coord = tf.train.Coordinator()
    threads = tf.train.start_queue_runners(coord=coord)

    image_tensor = sess.run([batch])
    print(batch)

    coord.request_stop()
    coord.join(threads)

另外,我还编写了一个可以成功读取图像的新文件(感谢 martianwars 的帮助)。 我的测试代码:

import tensorflow as tf    
# read and decode the image
image_contents = tf.read_file('Image_p/11247_left.jpeg')
image = tf.image.decode_jpeg(image_contents, channels=3)

with tf.Session() as sess:   
    img = sess.run(image)
    print(img)

最佳答案

image 将具有 (?, ?, 3) 形状,因为它尚未被读取,但您已在 decode_jpeg() 中指定了 channel 函数。尝试打印这个,

with tf.Session() as sess:   
    img = sess.run(image)
    print(img)

关于python - 无法在 tensorflow 中成功读取图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41439411/

相关文章:

python - 如何添加到 python 中的奇数索引值?

python - cv2.imshow() 函数如何在 BGR 模型中工作?

python - 加载 keras 模型时产生的警告

machine-learning - 有没有使用 MxNet 构建卷积自动编码器的玩具示例?

Python将纯文本显示为html

python - 如何编写良好的生成器链接函数

css - 随着窗口大小减小 CSS 从左侧截断图像

java - 循环以随机显示数组中的图像(Android)

python - 如何对某些十进制数据应用 scikit-learn 逻辑回归?

python - 如何防止选择第一行作为索引列