【OpenCV实现图像:用Python生成图像特效,报错ValueError: too many values to unpack (expected 3)】

文章目录

    • 概要
    • 读入图像
    • 改变单个通道
    • 黑白特效
    • 颜色反转
    • 将图像拆分成四个子部分

概要

Python是一种功能强大的编程语言,也是图像处理领域中常用的工具之一。通过使用Python的图像处理库(例如Pillow、OpenCV等),开发者可以实现各种各样的图像特效。这些特效包括但不限于:滤镜效果(如黑白、模糊、锐化等)、颜色转换、边缘检测、形状识别、图像合成和增强现实效果等。

在Python中,可以使用各种算法和技术来处理图像,例如卷积操作、颜色空间转换、形态学操作等。通过这些技术,开发者可以创建出令人惊叹的图像特效,用于美化照片、设计艺术作品、实现计算机视觉应用等。

图像处理的过程通常包括图像的读取、处理和保存。Python提供了简单而灵活的API,使得这些操作变得容易。开发者可以加载图像,对其进行各种操作,然后保存处理后的图像,以便后续使用或展示。

读入图像

# 导入Pillow库中的Image模块
from PIL import Image# 打开名为"landscape.jpg"的图像文件
img = Image.open('./landscape.jpg')# 获取图像的宽度和高度
width, height = img.size
print("图像宽度:", width, "图像高度:", height)# 遍历图像的每个像素点
for x in range(0, height):for y in range(0, width):# 获取当前像素点的红色(r)、绿色(g)、蓝色(b)通道的像素值(r, g, b) = img.getpixel((x, y))# 打印每个像素点的RGB值print("像素点 (x:", x, ", y:", y, ") 的RGB值: (R:", r, ", G:", g, ", B:", b, ")")

在以上代码片段中,我们使用了Python的Pillow库来进行图像处理。首先,我们打开了名为"landscape.jpg"的样例图像,并获取了图像的宽度和高度。接着,我们使用嵌套的循环遍历图像的所有像素点。在每个像素点,我们使用getpixel((x, y))方法获取了红色(r)、绿色(g)、蓝色(b)三个通道的像素值。

通过这个嵌套循环,我们可以逐个打印出图像中每个像素的RGB值,从而了解图像的构成。这种方式可以作为图像处理的基础,为后续的图像处理操作提供了基础数据。这样的操作使得我们能够更深入地了解图像,为后续的图像处理任务提供了必要的信息。
报错;

D:\anaconda\envs\yolov5\python.exe E:\yolo项目\Opencv-project-main\Opencv-project-main\CVZone\guangliu\33.py 
图像宽度: 938 图像高度: 613
Traceback (most recent call last):File "E:\yolo项目\Opencv-project-main\Opencv-project-main\CVZone\guangliu\33.py", line 15, in <module>(r, g, b) = img.getpixel((x, y))
ValueError: too many values to unpack (expected 3)Process finished with exit code 1

在这里插入图片描述
解决办法一:
错误提示表明在(r, g, b) = img.getpixel((x, y))这一行代码中,getpixel((x, y))返回的值不是期望的3个像素通道值(红、绿、蓝),而是更多的值,因此Python无法将这些值正确地分配给(r, g, b)。这种情况通常发生在图像模式(mode)不是RGB模式的时候。
可以在处理图像之前,将图像转换为RGB模式。

# 将图像转换为RGB模式
img = img.convert('RGB')

修改代码为:

# 导入Pillow库中的Image模块
from PIL import Image# 打开名为"landscape.jpg"的图像文件
img = Image.open('img_1.png')# 将图像转换为RGB模式
img = img.convert('RGB')# 获取图像的宽度和高度
width, height = img.size
print("图像宽度:", width, "图像高度:", height)# 遍历图像的每个像素点
for x in range(0, height):for y in range(0, width):# 获取当前像素点的红色(r)、绿色(g)、蓝色(b)通道的像素值(r, g, b) = img.getpixel((x, y))# 打印每个像素点的RGB值print("像素点 (x:", x, ", y:", y, ") 的RGB值: (R:", r, ", G:", g, ", B:", b, ")")

结果:
在这里插入图片描述

解决办法二:
修改传递参数即可,
将三个传递参数添加第四个d即可解决问题。

(r, g, b,d) = img.getpixel((x, y))

完整代码

# 导入Pillow库中的Image模块
from PIL import Image# 打开名为"landscape.jpg"的图像文件
img = Image.open('img_1.png')# 获取图像的宽度和高度
width, height = img.size
print("图像宽度:", width, "图像高度:", height)# 遍历图像的每个像素点
for x in range(0, height):for y in range(0, width):# 获取当前像素点的红色(r)、绿色(g)、蓝色(b)通道的像素值(r, g, b,d) = img.getpixel((x, y))# 打印每个像素点的RGB值print("像素点 (x:", x, ", y:", y, ") 的RGB值: (R:", r, ", G:", g, ", B:", b, ")")

结果依旧
在这里插入图片描述

改变单个通道

首先使用Pillow库打开了名为"landscape.jpg"的图像文件。然后,我们获取了图像的宽度和高度,并创建了一个新的图像对象new_img,它具有相同的大小。接着,我们使用嵌套的循环遍历原始图像的每个像素点。

在每个像素点,我们使用img.getpixel((col, row))获取红、绿、蓝三个通道的像素值。然后,我们将原始图像的绿色通道的像素值增加了50,创建了一个新的颜色。这个新颜色包含了原始红色通道的值(r),绿色通道的值增加了50(g+50),和原始蓝色通道的值(b)。最后,我们使用new_img.putpixel((col, row), (r, g + 50, b))将修改后的像素值放入新图像对象中。

# 导入Pillow库中的Image模块
from PIL import Image# 打开名为"landscape.jpg"的图像文件
img = Image.open('img_1.png')# 获取图像的宽度和高度
width, height = img.size
print("原始图像宽度:", width, "图像高度:", height)# 创建一个新的RGB模式的图像对象,具有相同的大小
new_img = Image.new('RGB', (width, height))# 遍历原始图像的每个像素点
for row in range(0, height):for col in range(0, width):# 获取当前像素点的红色(r)、绿色(g)、蓝色(b)通道的像素值(r, g, b) = img.getpixel((col, row))# 修改绿色通道的像素值,增加50new_green = g + 50# 将修改后的像素值放入新图像对象中new_img.putpixel((col, row), (r, new_green, b))# 将修改后的图像保存为"landscape_edited.png"文件
new_img.save("landscape_edited1.png")# 打印提示信息
print("图像处理完成,并保存为landscape_edited.png")

报错依旧:
在这里插入图片描述
按照上述方法二选一即可解决报错问题,我用添加的方法二避免报错。
完整代码

# 导入Pillow库中的Image模块
from PIL import Image# 打开名为"landscape.jpg"的图像文件
img = Image.open('img_1.png')# 获取图像的宽度和高度
width, height = img.size
print("原始图像宽度:", width, "图像高度:", height)# 创建一个新的RGB模式的图像对象,具有相同的大小
new_img = Image.new('RGB', (width, height))# 遍历原始图像的每个像素点
for row in range(0, height):for col in range(0, width):# 获取当前像素点的红色(r)、绿色(g)、蓝色(b)通道的像素值(r, g, b,d) = img.getpixel((col, row))# 修改绿色通道的像素值,增加50new_green = g + 50# 将修改后的像素值放入新图像对象中new_img.putpixel((col, row), (r, new_green, b,d))# 将修改后的图像保存为"landscape_edited.png"文件
new_img.save("landscape_edited1.png")# 打印提示信息
print("图像处理完成,并保存为landscape_edited.png")

结果:
在这里插入图片描述
这里也放方法一的结果:
在这里插入图片描述
依然可以完成这样的结果。

黑白特效

为了实现基本的黑白特效,我们必须确保所有3个通道都具有相同的值。

让我们再次迭代每个像素,并计算三个通道像素值的平均值:

# 导入Pillow库中的Image模块
from PIL import Image# 打开图片文件
img = Image.open('img_1.png')
# 将图像转换为RGB模式
img = img.convert('RGB')
# 获取图片的宽度和高度
width, height = img.size# 输出图片的宽度和高度
print("原始图片大小:", width, height)# 创建一张新的RGB模式的图片,大小与原始图片相同
new_img = Image.new('RGB', (width, height))# 遍历原始图片的每个像素
for row in range(0, height):for col in range(0, width):# 获取当前像素点的RGB颜色值(r, g, b) = img.getpixel((col, row))# 计算RGB三个通道的平均值,将像素点转换为灰度avg = int((r + g + b) / 3)# 在新图片上设置当前像素点的颜色为灰度值,实现黑白效果new_img.putpixel((col, row), (avg, avg, avg))# 将处理后的黑白图片保存为'landscape_black_and_white.jpg'
new_img.save("landscape_black_and_white.jpg")# 输出处理后的图片保存成功的消息
print("黑白图片已保存为'landscape_black_and_white.jpg'")

在这里插入图片描述

颜色反转

看懂了上述代码,那么颜色反转的实现现在应该会很简单!

简单来说。我们的目标是将黑色像素(0,0,0)转换为白色像素(255,255,255)。


from PIL import Imageimg = Image.open('img_1.png')
# 将图像转换为RGB模式
img = img.convert('RGB')
width, height = img.size
print(width, height)new_img = Image.new('RGB', (width, height))
for row in range(0, height):for col in range(0, width):(r, g, b) = img.getpixel((col, row))inverted_pixel = (255 - r, 255-g, 255-b)new_img.putpixel((col, row), inverted_pixel)
new_img.save("landscape_edited.jpg")

在这里插入图片描述

将图像拆分成四个子部分

from PIL import Imageimg = Image.open('img_1.png')
# 将图像转换为RGB模式
img = img.convert('RGB')
width, height = img.size
print(width, height)new_img = Image.new('RGB', (width, height))for row in range(0, height):for col in range(0, width):(r, g, b) = img.getpixel((col, row))if col < width * 0.25:(r, g, b) = (r, g, b)elif col < width * 0.5:avg = int((r + g + b) / 3)(r, g, b) = (avg, avg, avg)elif col < width * 0.75:(r, g, b) = (r, g + 50, b)else:(r, g, b) = (255 - r, 255 - g, 255 - b)new_img.putpixel((col, row), (r, g, b))new_img.save("landscape_edited.jpg")

在这里插入图片描述
小结:
机器学习报错解决2——ValueError: too many values to unpack (expected 3)
这个文章里面的东西被参考,我用来做方法二,可以说有点用,但是方法一是最好的办法,避免方法二的传参问题,如果有参数传递错误,或者是版本问题导致库的传参问题,可以使用方法二

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/154920.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

草莓熊代码

话不多说直接上代码 如果需要exe文件电脑可以不依赖环境直接运行请评论或者私信 注意: 不需要年月日显示 注释 879-894 行不需要雪花显示 注释 895-908 行不需要礼物显示 注释 771 行653行 可以修改 祝你节日快乐内容657行 可以修改 草莓熊 内容修改程序标题 第 16 行# -*- co…

简述JVM

文章目录 JVM简介JVM运行时数据区堆(线程共享)方法区/元空间/元数据区(线程共享)栈程序计数器 JVM类加载类加载过程双亲委派模型 垃圾回收机制(GC)判断对象是否为垃圾判断是否被引用指向 如何清理垃圾, 释放对象? JVM简介 JVM 是 Java Virtual Machine 的简称, 意为Java虚拟机…

加速计算卡设计方案:389-基于KU5P的双路100G光纤网络加速计算卡

基于KU5P的双路100G光纤网络加速计算卡 一、板卡概述 基于Xilinx UltraScale16 nm KU5P芯片方案基础上研发的一款双口100 G FPGA光纤以太网PCI-Express v3.0 x8智能加速计算卡&#xff0c;该智能卡拥有高吞吐量、低延时的网络处理能力以及辅助CPU进行网络功能卸载的能力…

Spring Security 6.1.x 系列(2)—— 基于过滤器的基础原理及源码解析(一)

一、过滤器 Spring Security 的 Servlet 支持基于 Servlet 过滤器&#xff0c;因此首先了解过滤器的作用会很有帮助。 下图为单个 HTTP 请求的处理程序的典型分层。 客户端向应用程序发送一个请求&#xff0c;运行容器创建一个FilterChain&#xff08;过滤链&#xff09;&…

Realtek 5G pcie网卡 RTL8126-CG简介

总shu&#xff1a;PCIE 5G网卡方案“RTL8126-CG”采用QFN56封装&#xff0c;面积8 x 8毫米&#xff0c;非常小巧&#xff0c;提供一个RJ-45网口、两个USB 3.x接口。它走的是PCIe 3.0 x1系统通道&#xff0c;搭配超五类网线&#xff0c;可以在长达100米的距离上提供满血的5Gbps网…

股权比例设计的九条生命线

股权比例设计——绝对控制线67% 【释义】一些重大事项如公司的股本变化&#xff0c;关于公司的增减资&#xff0c;修改公司章程&#xff0c; 分立/合并、变更主营项目等重大决策&#xff0c;需要2/3以上&#xff08;含2/3&#xff09;票数支持的。 股权比例设计——相对控制线…

Apollo上车实践:打造安全、高效、舒适的出行体验

上车实践 概述自动驾驶车辆适配线控标准协议开环验证车辆 自动驾驶车辆集成了解传感器布置与连接了解车辆标定了解传感器标定循迹实践 自动驾驶测试与调车了解车辆安全操作流程了解实车控制调试了解实车定位调试 福利活动 主页传送门&#xff1a;&#x1f4c0; 传送 概述 通过…

Linux--安装与配置虚拟机及虚拟机服务器坏境配置与连接---超详细教学

一&#xff0c;操作系统介绍 1.1.什么是操作系统 操作系统&#xff08;Operating System&#xff0c;简称OS&#xff09;是一种系统软件&#xff0c;它是计算机硬件和应用软件之间的桥梁。它管理计算机的硬件和软件资源&#xff0c;为应用程序提供接口和服务&#xff0c;并协调…

【配置环境】VS Code中JavaScript环境搭建

一&#xff0c;环境 Windows 11 家庭中文版&#xff0c;64 位操作系统, 基于 x64 的处理器VS Code 版本: 1.83.1 (user setup)Node.js 版本&#xff1a;20.9.0 二&#xff0c;为什么搭建JavaScript环境 因为在看《重构改善既有代码的设计第2版》的时候&#xff0c;书中的代码展…

概念解析 | 雷达动态范围

注1:本文系“概念解析”系列之一,致力于简洁清晰地解释、辨析复杂而专业的概念。本次辨析的概念是:雷达动态范围。 揭开雷达动态范围的神秘面纱 雷达动态范围是描述雷达系统性能的一个重要指标,它直接影响着雷达的检测能力。但是这个指标又比较抽象,对于非专业人员来说不太容易…

Apache ActiveMQ (版本 < 5.18.3) (CNVD-2023-69477)RCE修复方案/缓解方案

一、漏洞描述 Apache ActiveMQ 是美国阿帕奇&#xff08;Apache&#xff09;基金会的一套开源的消息中间件&#xff0c;它支持 Java 消息服务、集群、Spring Framework 等。 二、漏洞成因 ActiveMQ 默认开放了 61616 端口用于接收 OpenWire 协议消息&#xff0c;由于针对异常…

图纸管理制度《七》

1、目的&#xff1a; 明确技术图样与文件的签署、更改及标准化等内容&#xff0c;对技术图样与文件进行有效的控制。技术文化是公司的核心秘密&#xff0c;是公司能够持续发展并在市场上保持强势竞争力的有力保障&#xff0c;公司的技术文件属于公司所有&#xff0c;公司的每一…