opencv中cv2.imread()读取图片路径中包含中文路径的问题

问题描述:当使用cv2.imread读取图片路径包含中文时,会造成无法读入图片,而又不报错,其实什么都没有读入。

                  img = cv2.imread("./a/0000.桂JJJJJN.bmp")

原因:因为python 3.x 将系统字符编码默认为了Unicode,而opencv 读取图片函数的输入参数默认用gbk格式处理。

解决:

# 使用imdecode读入
img = cv2.imdecode(np.fromfile("./a/0000.桂JJJJJN.bmp",dtype=np.uint8),-1)
# 使用imdecode保存
cv2.imencode('.bmp', img)[1].tofile("车牌.jpg")

        定义读入图片的函数 

## 读取图像,解决imread不能读取中文路径的问题
def cv_imread(filePath):
    cv_img=cv2.imdecode(np.fromfile(filePath,dtype=np.uint8),-1)
    ## imdecode读取的是rgb,如果后续需要opencv处理的话,需要转换成bgr,转换后图片颜色会变化
    ##cv_img=cv2.cvtColor(cv_img,cv2.COLOR_RGB2BGR)

参考

你可能感兴趣的:(opencv)