opencv中对于Mat图像有专门的属性进行判断。
详见:https://blog.csdn.net/cv_walking/article/details/78315662?utm_source=distribute.pc_relevant.none-task
但是在python下的图片本质是用nparray表示的,所以这种调用方法会报异常:img.channels()。
所以需要按照nparray,判断他的shape或者他的维数来判断:
if img.ndim == 2: #2维度表示长宽
channels = 1 #单通道(grayscale)
elif img.ndim == 3:
channels = img.shape[-1] #第三维度表示通道,应为3
if(channels != 3): #应该是三才对
return -1
else: #异常维度,不是图片了
return -1