python opencv如何读取和显示图片_opencv-python读取并显示图像的基础操作

答案:使用OpenCV读取显示图像需正确调用cv2.imread()、cv2.imshow()、cv2.waitKey(0)和cv2.destroyAllWindows(),并注意路径格式、文件存在性及BGR颜色模式,避免窗口一闪而过或加载失败。

python opencv如何读取和显示图片_opencv-python读取并显示图像的基础操作

在Python中使用OpenCV库来读取和显示图片,核心操作其实非常直接,主要就是依靠

cv2.imread()

函数来加载图像,以及

cv2.imshow()

cv2.waitKey()

的组合来将其呈现在屏幕上,最后用

cv2.destroyAllWindows()

清理资源。这套流程可以说是在计算机视觉领域迈出的第一步,简单却至关重要。

解决方案

说起来,Python结合OpenCV处理图像,最基础的读取和显示操作,其实就那么几行代码。但别小看这几行,里面藏着不少细节,稍微不注意,程序可能就“一闪而过”,或者图片压根没显示出来。

首先,你需要确保已经安装了OpenCV。如果没有,

pip install opencv-python

就能搞定。

接着,我们来看核心代码:

立即学习“Python免费学习笔记(深入)”;

import cv2# 假设你的图片文件名为 'example.jpg',并且它和你的Python脚本在同一个目录下# 如果不在,你需要提供完整的路径,比如 'C:/Users/YourUser/Pictures/example.jpg'# 注意:Windows路径推荐使用正斜杠 '/' 或双反斜杠 '',或者使用原始字符串 r'C:...'image_path = 'example.jpg' # 读取图片# cv2.imread() 返回一个NumPy数组,代表了图片数据。# 第二个参数是可选的,比如 cv2.IMREAD_GRAYSCALE 可以直接读取灰度图img = cv2.imread(image_path)# 检查图片是否成功加载# 如果图片路径错误或文件损坏,imread会返回Noneif img is None:    print(f"错误:无法加载图片,请检查路径 '{image_path}' 是否正确或文件是否存在。")else:    # 创建一个窗口来显示图片    # 'Image Display' 是窗口的标题    cv2.imshow('Image Display', img)    # 等待按键    # cv2.waitKey(0) 表示无限期等待,直到用户按下任意键    # 如果是 cv2.waitKey(N),则表示等待N毫秒,N毫秒后无论是否按键都会继续执行    cv2.waitKey(0)    # 关闭所有OpenCV窗口    cv2.destroyAllWindows()print("程序执行完毕。")

这段代码是我个人觉得最直接、最基础的图像读取和显示范例。它涵盖了从导入库到错误处理,再到最终资源释放的完整流程。实际应用中,你可能需要根据图片来源、后续处理需求来调整

imread

的参数,或者更精细地控制

waitKey

的等待时间。

为什么我的OpenCV程序一闪而过,图片窗口瞬间消失?

这个问题,说实话,几乎所有初学者都会遇到。我刚开始接触OpenCV的时候,也为此困惑了好一阵子。你辛辛苦苦写完代码,运行一看,图片窗口就那么“咻”地一下,出现了又消失了,快得你根本看不清。这背后的“元凶”,其实就是

cv2.waitKey()

这个函数。

我们得明白,Python脚本是按顺序执行的。当你调用

cv2.imshow()

显示图片后,如果后面没有一个“暂停”的指令,脚本会立即执行下一行代码,直到结束。一旦脚本结束,它所创建的所有资源,包括那个图片显示窗口,都会被系统回收,自然就消失了。

cv2.waitKey()

的作用,就是给程序一个“等待用户输入”或者“等待一段时间”的机会。

cv2.waitKey(0)

: 这里的

0

是一个特殊值,它告诉OpenCV程序“无限期地等待用户按下键盘上的任意一个键”。只有当你按下某个键后,

waitKey()

才会返回按键的ASCII码,程序才会继续往下执行。这是最常用的方式,确保你有足够的时间看到图片。

cv2.waitKey(N)

(N > 0): 如果你传入一个正整数N,比如

cv2.waitKey(1000)

,那么程序会等待1000毫秒(即1秒)。在这1秒钟内,如果你按了键,它会立即返回;如果没有按键,1秒后它也会自动超时并返回-1,程序继续执行。这在视频播放或需要定时刷新图像的场景中非常有用。

所以,当你发现图片窗口一闪而过时,十有八九是你忘记了调用

cv2.waitKey(0)

,或者调用了但参数设置不当。加上它,你的图片就能安安静静地在那里等你仔细观察了。

另外,

cv2.destroyAllWindows()

cv2.destroyWindow('窗口名称')

是用来关闭OpenCV创建的窗口的。前者关闭所有,后者关闭指定名称的窗口。它们通常放在

waitKey()

之后,确保在程序结束前,所有窗口都被妥善关闭,释放系统资源。

处理不同图片格式或路径问题,OpenCV有哪些需要注意的细节?

在实际开发中,图片格式和文件路径是两个经常让人头疼的问题。OpenCV在处理这些时,确实有一些需要留心的细节。

关于图片格式:OpenCV支持的图片格式非常广泛,常见的如JPEG (.jpg, .jpeg)、PNG (.png)、BMP (.bmp)、TIFF (.tif, .tiff) 等等,基本都能无缝读取。这得益于它底层强大的图像编解码库。不过,这不意味着你可以完全不考虑格式。

兼容性与质量: JPEG是主流,但它是有损压缩,每次保存都会损失一点质量。PNG是无损压缩,适合需要保留细节或包含透明通道的图像。根据你的应用场景选择合适的格式进行保存或处理,是很重要的。特殊格式: 偶尔会遇到一些非常规的图像格式,或者图片文件本身可能损坏了。这时

cv2.imread()

很可能会返回

None

。所以,永远要检查

imread

的返回值,这是编写健壮代码的基本原则。一个简单的

if img is None:

判断能帮你避免很多运行时错误。颜色通道: OpenCV默认读取的彩色图片是BGR格式(蓝、绿、红),而不是我们更熟悉的RGB。这在进行颜色处理或与其他库(如Matplotlib)交互时需要特别注意,可能需要

cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

进行转换。

关于路径问题:文件路径是另一个“坑”。不同操作系统、不同开发环境,对路径的表示方式都有细微差别。

绝对路径与相对路径:

绝对路径是文件在文件系统中的完整位置,比如

C:/Users/User/image.jpg

/home/user/image.jpg

。优点是明确,不容易出错;缺点是代码移植性差,换个环境可能就要改。相对路径是相对于当前Python脚本执行目录的位置,比如

image.jpg

(与脚本同目录)或

./data/image.jpg

。优点是移植性好,缺点是如果脚本执行目录不确定,很容易找不到文件。建议: 对于测试或小型项目,相对路径方便。对于大型项目或需要部署的应用,通常会使用配置来管理路径,或者通过

os.path

模块来构建平台无关的路径。

Windows路径分隔符: Windows系统习惯用反斜杠


作为路径分隔符,比如

C:UsersDesktopimage.jpg

。但在Python字符串中,反斜杠是转义字符。所以,如果你直接写

'C:Users...'

,Python会报错或者解释成奇怪的路径。解决方案有几种:

使用正斜杠

/

'C:/Users/Desktop/image.jpg'

。这是最推荐的方式,因为它在所有操作系统上都有效。使用双反斜杠


'C:UsersDesktopimage.jpg'

。Python会将


解释为一个普通的反斜杠。使用原始字符串

r''

r'C:UsersDesktopimage.jpg'

。在字符串前加

r

,表示这是一个原始字符串,里面的反斜杠不再是转义字符。

检查文件是否存在: 在尝试读取图片之前,用

os.path.exists(image_path)

检查一下文件是否存在,是一个很好的习惯。这能提前发现路径错误,避免

imread

返回

None

后才处理。

处理好这些细节,能让你的OpenCV图像处理程序更加稳定和可靠。

除了基础显示,OpenCV还能对图像进行哪些初步操作?

一旦你成功读取并显示了图像,OpenCV的强大功能才刚刚展现出冰山一角。在深入复杂的图像处理算法之前,有一些非常基础但又极其常用的初步操作,它们往往是后续一切处理的起点。

灰度化处理:这是最常见的初步操作之一。很多图像处理算法(比如边缘检测、特征点提取)在灰度图上效果更好,或者说,它们根本就不需要彩色信息。将彩色图像转换为灰度图,可以大大减少数据量,加快处理速度。OpenCV提供了一个非常方便的函数:

gray_img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)cv2.imshow('Grayscale Image', gray_img)cv2.waitKey(0)cv2.destroyAllWindows()
cv2.COLOR_BGR2GRAY

就是告诉OpenCV,将BGR格式的彩色图转换为灰度图。

图像尺寸调整(Resizing):你可能会遇到图片太大,不方便显示或处理;或者需要将多张图片统一尺寸进行比较。调整图像大小是必不可少的。

# 缩小到一半resized_img_half = cv2.resize(img, (img.shape[1] // 2, img.shape[0] // 2))# 调整到固定尺寸,比如 300x200fixed_size_img = cv2.resize(img, (300, 200))cv2.imshow('Resized Image', resized_img_half)cv2.imshow('Fixed Size Image', fixed_size_img)cv2.waitKey(0)cv2.destroyAllWindows()
cv2.resize()

函数允许你指定新的宽度和高度。它还有不同的插值方法(如

cv2.INTER_LINEAR

cv2.INTER_CUBIC

),用于在调整大小时计算新像素值,这会影响图像质量,特别是放大时。

保存处理后的图像:当你对图像进行了灰度化、尺寸调整或其他任何操作后,你肯定希望将结果保存下来。

cv2.imwrite()

就是为此而生。

# 假设 gray_img 是你处理后的灰度图像cv2.imwrite('grayscale_example.jpg', gray_img)# 假设 fixed_size_img 是你调整尺寸后的图像cv2.imwrite('resized_example.png', fixed_size_img)print("处理后的图像已保存。")
cv2.imwrite()

的第一个参数是保存路径和文件名(包括扩展名),第二个参数是要保存的图像数据。OpenCV会根据你提供的文件扩展名自动选择合适的编码器。

获取图像属性:了解图像的基本属性,比如它的尺寸、通道数,是进行后续处理的基础。

print(f"图像尺寸 (高, 宽, 通道数): {img.shape}")print(f"图像像素总数: {img.size}")print(f"图像数据类型: {img.dtype}")
img.shape

会返回一个元组,彩色图像通常是

(height, width, channels)

,灰度图像则是

(height, width)

img.size

是总像素点数(如果彩色,则为高通道数),

img.dtype

是像素值的数据类型,通常是

uint8

(无符号8位整数,0-255)。

这些初步操作,虽然看起来简单,却是构建更复杂图像处理流程的基石。掌握它们,你就能更好地理解图像数据,并为后续的进阶操作打下坚实的基础。

以上就是python opencv如何读取和显示图片_opencv-python读取并显示图像的基础操作的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1371330.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 11:21:06
下一篇 2025年12月14日 11:21:29

相关推荐

  • CSS mask属性无法获取图片:为什么我的图片不见了?

    CSS mask属性无法获取图片 在使用CSS mask属性时,可能会遇到无法获取指定照片的情况。这个问题通常表现为: 网络面板中没有请求图片:尽管CSS代码中指定了图片地址,但网络面板中却找不到图片的请求记录。 问题原因: 此问题的可能原因是浏览器的兼容性问题。某些较旧版本的浏览器可能不支持CSS…

    2025年12月24日
    900
  • Uniapp 中如何不拉伸不裁剪地展示图片?

    灵活展示图片:如何不拉伸不裁剪 在界面设计中,常常需要以原尺寸展示用户上传的图片。本文将介绍一种在 uniapp 框架中实现该功能的简单方法。 对于不同尺寸的图片,可以采用以下处理方式: 极端宽高比:撑满屏幕宽度或高度,再等比缩放居中。非极端宽高比:居中显示,若能撑满则撑满。 然而,如果需要不拉伸不…

    2025年12月24日
    400
  • 如何让小说网站控制台显示乱码,同时网页内容正常显示?

    如何在不影响用户界面的情况下实现控制台乱码? 当在小说网站上下载小说时,大家可能会遇到一个问题:网站上的文本在网页内正常显示,但是在控制台中却是乱码。如何实现此类操作,从而在不影响用户界面(UI)的情况下保持控制台乱码呢? 答案在于使用自定义字体。网站可以通过在服务器端配置自定义字体,并通过在客户端…

    2025年12月24日
    800
  • 如何在地图上轻松创建气泡信息框?

    地图上气泡信息框的巧妙生成 地图上气泡信息框是一种常用的交互功能,它简便易用,能够为用户提供额外信息。本文将探讨如何借助地图库的功能轻松创建这一功能。 利用地图库的原生功能 大多数地图库,如高德地图,都提供了现成的信息窗体和右键菜单功能。这些功能可以通过以下途径实现: 高德地图 JS API 参考文…

    2025年12月24日
    400
  • 如何使用 scroll-behavior 属性实现元素scrollLeft变化时的平滑动画?

    如何实现元素scrollleft变化时的平滑动画效果? 在许多网页应用中,滚动容器的水平滚动条(scrollleft)需要频繁使用。为了让滚动动作更加自然,你希望给scrollleft的变化添加动画效果。 解决方案:scroll-behavior 属性 要实现scrollleft变化时的平滑动画效果…

    2025年12月24日
    000
  • 如何为滚动元素添加平滑过渡,使滚动条滑动时更自然流畅?

    给滚动元素平滑过渡 如何在滚动条属性(scrollleft)发生改变时为元素添加平滑的过渡效果? 解决方案:scroll-behavior 属性 为滚动容器设置 scroll-behavior 属性可以实现平滑滚动。 html 代码: click the button to slide right!…

    2025年12月24日
    500
  • 为什么设置 `overflow: hidden` 会导致 `inline-block` 元素错位?

    overflow 导致 inline-block 元素错位解析 当多个 inline-block 元素并列排列时,可能会出现错位显示的问题。这通常是由于其中一个元素设置了 overflow 属性引起的。 问题现象 在不设置 overflow 属性时,元素按预期显示在同一水平线上: 不设置 overf…

    2025年12月24日 好文分享
    400
  • 网页使用本地字体:为什么 CSS 代码中明明指定了“荆南麦圆体”,页面却仍然显示“微软雅黑”?

    网页中使用本地字体 本文将解答如何将本地安装字体应用到网页中,避免使用 src 属性直接引入字体文件。 问题: 想要在网页上使用已安装的“荆南麦圆体”字体,但 css 代码中将其置于第一位的“font-family”属性,页面仍显示“微软雅黑”字体。 立即学习“前端免费学习笔记(深入)”; 答案: …

    2025年12月24日
    000
  • 如何选择元素个数不固定的指定类名子元素?

    灵活选择元素个数不固定的指定类名子元素 在网页布局中,有时需要选择特定类名的子元素,但这些元素的数量并不固定。例如,下面这段 html 代码中,activebar 和 item 元素的数量均不固定: *n *n 如果需要选择第一个 item元素,可以使用 css 选择器 :nth-child()。该…

    2025年12月24日
    200
  • 使用 SVG 如何实现自定义宽度、间距和半径的虚线边框?

    使用 svg 实现自定义虚线边框 如何实现一个具有自定义宽度、间距和半径的虚线边框是一个常见的前端开发问题。传统的解决方案通常涉及使用 border-image 引入切片图片,但是这种方法存在引入外部资源、性能低下的缺点。 为了避免上述问题,可以使用 svg(可缩放矢量图形)来创建纯代码实现。一种方…

    2025年12月24日
    100
  • 如何解决本地图片在使用 mask JS 库时出现的跨域错误?

    如何跨越localhost使用本地图片? 问题: 在本地使用mask js库时,引入本地图片会报跨域错误。 解决方案: 要解决此问题,需要使用本地服务器启动文件,以http或https协议访问图片,而不是使用file://协议。例如: python -m http.server 8000 然后,可以…

    2025年12月24日
    200
  • 如何让“元素跟随文本高度,而不是撑高父容器?

    如何让 元素跟随文本高度,而不是撑高父容器 在页面布局中,经常遇到父容器高度被子元素撑开的问题。在图例所示的案例中,父容器被较高的图片撑开,而文本的高度没有被考虑。本问答将提供纯css解决方案,让图片跟随文本高度,确保父容器的高度不会被图片影响。 解决方法 为了解决这个问题,需要将图片从文档流中脱离…

    2025年12月24日
    000
  • 为什么我的特定 DIV 在 Edge 浏览器中无法显示?

    特定 DIV 无法显示:用户代理样式表的困扰 当你在 Edge 浏览器中打开项目中的某个 div 时,却发现它无法正常显示,仔细检查样式后,发现是由用户代理样式表中的 display none 引起的。但你疑问的是,为什么会出现这样的样式表,而且只针对特定的 div? 背后的原因 用户代理样式表是由…

    2025年12月24日
    200
  • CSS元素设置em和transition后,为何载入页面无放大效果?

    css元素设置em和transition后,为何载入无放大效果 很多开发者在设置了em和transition后,却发现元素载入页面时无放大效果。本文将解答这一问题。 原问题:在视频演示中,将元素设置如下,载入页面会有放大效果。然而,在个人尝试中,并未出现该效果。这是由于macos和windows系统…

    2025年12月24日
    200
  • inline-block元素错位了,是为什么?

    inline-block元素错位背后的原因 inline-block元素是一种特殊类型的块级元素,它可以与其他元素行内排列。但是,在某些情况下,inline-block元素可能会出现错位显示的问题。 错位的原因 当inline-block元素设置了overflow:hidden属性时,它会影响元素的…

    2025年12月24日
    000
  • 为什么 CSS mask 属性未请求指定图片?

    解决 css mask 属性未请求图片的问题 在使用 css mask 属性时,指定了图片地址,但网络面板显示未请求获取该图片,这可能是由于浏览器兼容性问题造成的。 问题 如下代码所示: 立即学习“前端免费学习笔记(深入)”; icon [data-icon=”cloud”] { –icon-cl…

    2025年12月24日
    200
  • 为什么使用 inline-block 元素时会错位?

    inline-block 元素错位成因剖析 在使用 inline-block 元素时,可能会遇到它们错位显示的问题。如代码 demo 所示,当设置了 overflow 属性时,a 标签就会错位下沉,而未设置时却不会。 问题根源: overflow:hidden 属性影响了 inline-block …

    2025年12月24日
    000
  • 如何利用 CSS 选中激活标签并影响相邻元素的样式?

    如何利用 css 选中激活标签并影响相邻元素? 为了实现激活标签影响相邻元素的样式需求,可以通过 :has 选择器来实现。以下是如何具体操作: 对于激活标签相邻后的元素,可以在 css 中使用以下代码进行设置: li:has(+li.active) { border-radius: 0 0 10px…

    2025年12月24日
    100
  • 为什么我的 CSS 元素放大效果无法正常生效?

    css 设置元素放大效果的疑问解答 原提问者在尝试给元素添加 10em 字体大小和过渡效果后,未能在进入页面时看到放大效果。探究发现,原提问者将 CSS 代码直接写在页面中,导致放大效果无法触发。 解决办法如下: 将 CSS 样式写在一个单独的文件中,并使用 标签引入该样式文件。这个操作与原提问者观…

    2025年12月24日
    000
  • 如何模拟Windows 10 设置界面中的鼠标悬浮放大效果?

    win10设置界面的鼠标移动显示周边的样式(探照灯效果)的实现方式 在windows设置界面的鼠标悬浮效果中,光标周围会显示一个放大区域。在前端开发中,可以通过多种方式实现类似的效果。 使用css 使用css的transform和box-shadow属性。通过将transform: scale(1.…

    2025年12月24日
    200

发表回复

登录后才能评论
关注微信