Python使用OpenCV读取图片返回None排查及解决技巧
作者:我材不敲代码
这段描述主要讲解了使用OpenCV读取图片时遇到读取图片为空(None)问题的解决方法,重点包括路径问题、图片本身问题和权限问题三大方面,详细解析了路径错误、图片损坏、权限不足等常见问题,并并提供解决方案和排查代码,需要的朋友可以参考下
使用 OpenCV 做图像处理时,最让人头疼的问题之一就是:cv2.imread() 读出来的图片是空(None),程序直接报错 AttributeError: 'NoneType' object has no attribute 'shape'。
一、先确认:你的图片真的是空吗?
首先用两行代码快速判断,读出来的对象是不是 None:
import cv2
img = cv2.imread("test.jpg")
print(img) # 输出 None 就是读取失败
print(type(img)) # <class 'NoneType'> 代表读取失败
只要输出 None,就说明 图片路径错误 / 权限不足 / 格式不支持 / 图片损坏,下面逐个排查!
二、最常见原因:路径问题(80% 的人栽在这里)
1. 相对路径错误(新手重灾区)
cv2.imread() 的相对路径是相对于「当前运行 Python 的工作目录」,不是你写代码的 .py 文件所在目录!
错误示例:
- 代码文件在
D:/project/test.py - 图片放在
D:/project/img/test.jpg - 你运行命令的目录是
D:/ - 写
img = cv2.imread("img/test.jpg")就会失败
解决方法:
- 使用绝对路径(最稳妥,推荐新手用)
# Windows 绝对路径
img = cv2.imread("D:/project/img/test.jpg")
# 或者用反斜杠,但必须加 r 转义
img = cv2.imread(r"D:\project\img\test.jpg")
- 获取代码文件所在目录,拼接路径(兼容性最强)
import cv2 import os # 获取当前 .py 文件的绝对路径 base_path = os.path.dirname(os.path.abspath(__file__)) # 拼接图片路径 img_path = os.path.join(base_path, "img", "test.jpg") img = cv2.imread(img_path)
2. 路径包含中文 / 特殊字符
OpenCV 默认不支持中文路径!这是超级大坑!
错误:
img = cv2.imread("D:/测试文件夹/图片.jpg") # 直接返回 None
解决方法(万能方案):
import cv2
import numpy as np
# 先用 imdecode 读取,支持中文路径
def cv_imread(file_path):
# 读取图片字节数据
cv_img = cv2.imdecode(np.fromfile(file_path, dtype=np.uint8), cv2.IMREAD_COLOR)
return cv_img
# 使用这个函数代替 cv2.imread
img = cv_imread("D:/测试文件夹/图片.jpg")
3. 路径中空格、拼写错误
- 检查文件名:
test .jpg(多了空格)、tes.jpg(拼写错误) - 检查后缀:
.png写成.pnj、.jpg写成.jpeg
三、第二大原因:图片本身问题
1. 图片损坏 / 未下载完成
- 图片下载一半中断、传输失败、文件损坏
- 用系统图片查看器打开,如果打不开 / 显示空白,OpenCV 肯定读不出来
解决:重新下载 / 替换正常图片
2. 图片格式不支持
OpenCV 支持:jpg、jpeg、png、bmp、tiff 等常见格式
不支持:
- WebP 格式(直接读会失败)
- HEIC(苹果手机格式)
- 动图 GIF
解决:
- WebP 用
PIL先转成 PNG/JPG 再读 - HEIC 用
pyheif库转换
四、权限 / 文件被占用
- 图片被其他软件占用(如图片查看器、PS 打开着)
- 文件权限不足(Linux/macOS 下没有读权限)
Linux/macOS 赋权命令:
chmod 644 你的图片路径
五、OpenCV 安装问题
如果所有路径、图片都正常,还是读不出来,大概率是 OpenCV 装错了:
常见错误安装:
# 不推荐,缺少依赖库 pip install opencv-python
推荐安装:
# 完整版本,包含所有依赖(解决大部分底层读取失败) pip install opencv-contrib-python
安装后重启 Python 环境!
六、终极排查代码(直接复制用)
把这段代码放到你的项目里,自动检测所有错误原因:
import cv2
import os
def check_image_read(img_path):
# 1. 判断文件是否存在
if not os.path.exists(img_path):
print("错误:文件不存在!")
return None
# 2. 判断是否是文件
if not os.path.isfile(img_path):
print("错误:这不是一个文件!")
return None
# 3. 读取图片
img = cv2.imread(img_path)
# 4. 判断是否读取成功
if img is None:
print("错误:cv2.imread 读取失败!")
print("可能原因:中文路径/图片损坏/格式不支持/权限不足")
# 尝试用中文路径兼容方案读取
try:
import numpy as np
img = cv2.imdecode(np.fromfile(img_path, dtype=np.uint8), cv2.IMREAD_COLOR)
if img is not None:
print("已自动用中文路径方案修复!")
except:
pass
else:
print("图片读取成功!图片形状:", img.shape)
return img
# 测试
if __name__ == "__main__":
# 替换成你的图片路径
image_path = "test.jpg"
check_image_read(image_path)
七、总结:快速排查口诀
- 先打印看是否 None,确定是读取失败
- 路径优先查:绝对路径 / 中文 / 拼写 / 空格
- 图片本身查:损坏 / 格式 / 后缀
- 权限占用查:关闭占用软件、赋权
- 库重装:用
opencv-contrib-python - 中文路径必用 imdecode
总结
cv2.imread()返回None90% 是路径问题,优先用绝对路径- 中文路径必须用
cv2.imdecode()方案 - 图片损坏、格式不支持、权限不足也会导致读取失败
- 终极方案:复制我写的排查代码,一键定位问题
以上就是Python使用OpenCV读取图片返回None排查及解决技巧的详细内容,更多关于Python OpenCV读取图片返回None的资料请关注脚本之家其它相关文章!
