2017-08-25 300 views
1

,当我运行我的代码,我得到的错误是这样的:tensorflow:蹊跷的“tf.gfile.GFile”与“‘UTF-8’编解码器不能解码......”

File "data2record.py", line 120, in <module> 
    run() 
    File "data2record.py", line 114, in run 
    image_data, shape, bbox, label ,imname= _processing_image(wordbb, imname,coder) 
    File "data2record.py", line 64, in _processing_image 
    image_data = tf.gfile.GFile(FLAGS.datasets + imname, 'r').read() 
    File "/home/tian/.local/lib/python3.5/site-packages/tensorflow/python/lib/io/file_io.py", line 125, in read 
    pywrap_tensorflow.ReadFromStream(self._read_buf, length, status)) 
    File "/home/tian/.local/lib/python3.5/site-packages/tensorflow/python/lib/io/file_io.py", line 93, in _prepare_value 
    return compat.as_str_any(val) 
    File "/home/tian/.local/lib/python3.5/site-packages/tensorflow/python/util/compat.py", line 106, in as_str_any 
    return as_str(value) 
    File "/home/tian/.local/lib/python3.5/site-packages/tensorflow/python/util/compat.py", line 84, in as_text 
    return bytes_or_text.decode(encoding) 
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte 

在我的代码中的错误行是:

... 
image_data = tf.gfile.GFile(FLAGS.datasets + imname, 'r').read() 
image = coder.decode_jpeg(image_data) 
... 

我tensorflow是1.3和Python是3.5.And这个代码可以在tensorflow 1.0运行,蟒蛇2.7.Why它不能在tensorflow运行是1.3和python是3.5? 代码位于datasets/data2record.py中:https://github.com/xiaodiu2010/TextBoxes-TensorFlow 有人可以帮助我吗?

回答

1

就像错误说的,因为它试图解码文件数据到unicode和失败。

更改行:

image_data = tf.gfile.GFile(FLAGS.datasets + imname, 'r').read()

到:

image_data = tf.gfile.GFile(FLAGS.datasets + imname, 'rb').read()

要阅读二进制模式的文件。它在Py2中工作,因为默认情况下str是一个字节字符串,而在Py3中它是一个unicode字符串,因此在文本模式下读取文件时需要解码。

+0

很有效。非常感谢! –

相关问题