python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > Python OpenCV读取图片返回None

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 文件所在目录!

错误示例:

解决方法:

  1. 使用绝对路径(最稳妥,推荐新手用)
# Windows 绝对路径
img = cv2.imread("D:/project/img/test.jpg")  
# 或者用反斜杠,但必须加 r 转义
img = cv2.imread(r"D:\project\img\test.jpg")
  1. 获取代码文件所在目录,拼接路径(兼容性最强)
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. 路径中空格、拼写错误

三、第二大原因:图片本身问题

1. 图片损坏 / 未下载完成

解决:重新下载 / 替换正常图片

2. 图片格式不支持

OpenCV 支持:jpg、jpeg、png、bmp、tiff 等常见格式

不支持:

解决:

  1. WebP 用 PIL 先转成 PNG/JPG 再读
  2. HEIC 用 pyheif 库转换

四、权限 / 文件被占用

  1. 图片被其他软件占用(如图片查看器、PS 打开着)
  2. 文件权限不足(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)

七、总结:快速排查口诀

  1. 先打印看是否 None,确定是读取失败
  2. 路径优先查:绝对路径 / 中文 / 拼写 / 空格
  3. 图片本身查:损坏 / 格式 / 后缀
  4. 权限占用查:关闭占用软件、赋权
  5. 库重装:用 opencv-contrib-python
  6. 中文路径必用 imdecode

总结

  1. cv2.imread() 返回 None 90% 是路径问题,优先用绝对路径
  2. 中文路径必须用 cv2.imdecode() 方案
  3. 图片损坏、格式不支持、权限不足也会导致读取失败
  4. 终极方案:复制我写的排查代码,一键定位问题

以上就是Python使用OpenCV读取图片返回None排查及解决技巧的详细内容,更多关于Python OpenCV读取图片返回None的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文