python3中cv2.imread返回NoneType的解决方法

这两天做东西真是诸事不顺,caffe各种爆炸,今天在转换数据集格式的时候python又炸了,具体情况如下:

环境anacond3,python3,opencv3,

代码中cv2.imread(train_filepath)后返回NoneType,百度了一圈大都是说路径不对,opencv-python包不对之类的问题,于是我仔细检查各种路径没有问题后,将anaconda到各种包全update了一遍,结果悲伤逆流成河,问题并没有解决。

把图片放到程序同目录下用相对路径打开后发现没有问题,于是将问题锁定在路径上。这时注意到我的路径中有中文,python一向在中文支持上令人心碎,这时将关键词锁定在python imread 中文路径上,于是发现了一种解决方案:

cv2.imread(srcfile.encode('gbk'))

结果。。。。。依然杯具。。。。。

就在我即将原地爆炸的时候,发现了另一篇文章,文章中说上述解决方法是针对python2的,在python3中由于python3字符串采用utf8编码,cv2.imread将utf8当作本地码(如GBK),因此替代方案如下:

# imread
img = cv2.imdecode(np.fromfile(u'x:/中文路径/xx.jpg', dtype=np.uint8), flags)  #flags=cv2.IMREAD_COLOR...
#imwrite
cv2.imencode('.jpg', img)[1].tofile(u'x:/中文路径/xx.jpg')

顺利解决。

再次吐槽py的中文编码问题。

 

posted @ 2017-10-18 23:30  木易修  阅读(14237)  评论(0编辑  收藏  举报