错误示范
import os
import cv2
org_p=r'F:/pycharm/charSamples/test/'
class_path = org_p + '浙' + '/'
for img_name in os.listdir(class_path):
imgpath = class_path + img_name
print(imgpath)
img = cv2.imread(imgpath)
cv2.imwrite(imgpath,img)
正确方法
import os
import cv2
import numpy as np
org_p=r'F:/pycharm/charSamples/test/'
class_path = org_p + '浙' + '/'
for img_name in os.listdir(class_path):
imgpath = class_path + img_name
img=cv2.imdecode(np.fromfile(imgpath, dtype=np.uint8), cv2.IMREAD_UNCHANGED)
cv2.imencode('.jpg', img)[1].tofile(imgpath)
需要注意的是:
1.如果只改变读取图片的方式,不改变保存图片的方式是不会报错的,但是不能够保存。
2.名字中不包含中文的图片是不能这样存取的。
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------
随后又发现使Image可以避免汉字的问题。
import os
from PIL import Image
#将图片转为统一黑白8位
#test org_p=r'F:/pycharm/charSamples/test/'
#test filename=r'F:/pycharm/charSamples/testgray/'
#org_p=r'F:/pycharm/charSamples/train/training-set/'#训练图片
#filename=r'F:/pycharm/charSamples/traingray/training-set/'#训练图片
org_p=r'F:/pycharm/charSamples/train/validation-set/'#验证图片
filename=r'F:/pycharm/charSamples/traingray/validation-set/'#验证图片
classes={'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'J', 'K', 'L', 'M', 'N', 'P',
'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z','藏','川','鄂','甘','赣','贵','桂','黑','沪','吉','冀','津','晋','京','辽','鲁','蒙','闽','宁','青','琼',
'陕','苏','皖','湘','新','渝','豫','粤','云','浙'}
for index,name in enumerate(classes):#遍历所有含图片的文件夹
class_path=org_p+name+'/'
class_path_new=filename+name+'/'
for img_name in os.listdir(class_path):
imgpath=class_path+img_name
imgnewpath=class_path_new+img_name
imgpath = class_path + img_name
imgpathnew = class_path_new + img_name
print(imgpath)
img = Image.open(imgpath)
img1 = img.convert('1')
img1.save(imgpathnew)
print("第%d类的数据已加载完"%(index+1))

本文介绍了在含有中文路径的文件系统中正确读取和保存图片的方法,对比了使用OpenCV与PIL库的不同实现方式,并针对不同情况提供了有效的解决方案。

3297

被折叠的 条评论
为什么被折叠?



