Python使用OpenCV读取图片返回None排查及解决技巧

 更新时间:2026年05月29日 08:54:43   作者:我材不敲代码  
这段描述主要讲解了使用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") 就会失败

解决方法:

  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. 路径中空格、拼写错误

  • 检查文件名:test .jpg(多了空格)、tes.jpg(拼写错误)
  • 检查后缀:.png 写成 .pnj.jpg 写成 .jpeg

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

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

  • 图片下载一半中断、传输失败、文件损坏
  • 用系统图片查看器打开,如果打不开 / 显示空白,OpenCV 肯定读不出来

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

2. 图片格式不支持

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

不支持:

  • WebP 格式(直接读会失败)
  • HEIC(苹果手机格式)
  • 动图 GIF

解决:

  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的资料请关注脚本之家其它相关文章!

相关文章

  • Python 单元测试(unittest)的使用小结

    Python 单元测试(unittest)的使用小结

    Python中有一个自带的单元测试框架是unittest模块,用它来做单元测试,本篇文章主要介绍了Python 单元测试(unittest)的使用小结,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-11-11
  • Selenium环境变量配置(火狐浏览器)及验证实现

    Selenium环境变量配置(火狐浏览器)及验证实现

    这篇文章主要介绍了Selenium环境变量配置(火狐浏览器)及验证实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • Pyqt5实战小案例之界面与逻辑分离的小计算器程序

    Pyqt5实战小案例之界面与逻辑分离的小计算器程序

    网上很多PyQt5信号槽与界面分离的例子,但是真正开发起来很不方便,下面这篇文章主要给大家介绍了关于Pyqt5实战小案例之界面与逻辑分离的小计算器程序,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-02-02
  • Python + Streamlit项目部署方案超详细教程(非Docker版)

    Python + Streamlit项目部署方案超详细教程(非Docker版)

    Streamlit是一款强大的Python框架,专为机器学习及数据可视化打造,这篇文章主要介绍了Python + Streamlit项目部署方案(非Docker版)的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-11-11
  • python正则表达式re模块的使用示例详解

    python正则表达式re模块的使用示例详解

    这篇文章主要为大家介绍了python正则表达式re模块的使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • Python之is与==的区别详解

    Python之is与==的区别详解

    这篇文章主要介绍了Python之is与==的区别详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • python直接调用和使用swig法方调用c++库

    python直接调用和使用swig法方调用c++库

    这篇文章主要介绍了python直接调用和使用swig法方调用c++库,c++运算速度快于python,python简单易写。很多时候对于已有的c++代码也不想用python重写,此时就自然而然地想到用python调用c或者c++,两全其美,需要的朋友可以参考一下
    2022-03-03
  • 基于MSELoss()与CrossEntropyLoss()的区别详解

    基于MSELoss()与CrossEntropyLoss()的区别详解

    今天小编就为大家分享一篇基于MSELoss()与CrossEntropyLoss()的区别详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-01-01
  • 用Python的Django框架完成视频处理任务的教程

    用Python的Django框架完成视频处理任务的教程

    这篇文章主要介绍了用Python的Django框架完成视频处理任务的教程,包括用户的视频上传和播放以及下载功能的实现,需要的朋友可以参考下
    2015-04-04
  • Python学习之循环方法详解

    Python学习之循环方法详解

    循环是有着周而复始的运动或变化的规律;在 Python 中,循环的操作也叫做 遍历。与现实中一样,Python 中也同样存在着无限循环的方法与有限循环的方法。本文将通过示例详细讲解Python中的循环方法,需要的可以参考一下
    2022-03-03

最新评论