news 2026/4/16 14:34:07

Python | OpenCV | 图像处理 | 入门实验 | 对比度增强 | 裁剪

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python | OpenCV | 图像处理 | 入门实验 | 对比度增强 | 裁剪

0. 前言
“图像处理”听起来高大上,其实用 20 行 Python 就能跑起来。
今天带大家在 10 分钟 内完成一次真实可跑的实验:

把一张机器人照片 robot.jpg 切成左上角;

再把亮度 / 对比度拉满;

最后保存成新图 robot_enhanced.jpg。

读完你就能向室友炫耀:我写的代码能让照片“发光”!

1. 准备战场
表格

复制

项目 版本 备注
Python 3.8+ 自带即可
OpenCV-Python 4.10+ 一条命令装好
系统 Win / macOS / Linux 不限
1.1 一键安装 OpenCV
打开终端(Windows 用 PowerShell / CMD 都行)依次复制:

bash

复制

# 升级 pip,防止装包失败
python -m pip install --upgrade pip
# 用阿里镜像秒装
pip install opencv-python -i https://mirrors.aliyun.com/pypi/simple/
# 验证版本
pip show opencv-python
一键获取完整项目代码
看到 Version: 4.x.x 就说明 OK。

1.2 拿到素材
把下面两个文件放到 同一个文件夹(路径别带中文):

robot.jpg(实验原图)

image_process.py(下文代码,复制即用)

2. 核心 20 行代码
新建文件 image_process.py,复制保存:

Python

复制

import cv2
import os

# 1. 读图
img = cv2.imread('robot.jpg')
assert img is not None, 'robot.jpg 没读到,确认路径!'

# 2. 裁剪:左上角 1/4
h, w = img.shape[:2]
roi = img[0:h//2, 0:w//2]

# 3. 对比度+亮度增强
# alpha>1 对比度↑,beta>0 亮度↑
enhanced = cv2.convertScaleAbs(roi, alpha=1.8, beta=30)

# 4. 保存
out = 'robot_enhanced.jpg'
cv2.imwrite(out, enhanced)
print(f'✅ 已生成:{os.path.abspath(out)}')

# 5. 弹窗预览(按任意键关闭)
cv2.imshow('before', img)
cv2.imshow('after', enhanced)
cv2.waitKey(0)
cv2.destroyAllWindows()
一键获取完整项目代码

3. 跑起来!
终端切到该目录,执行:

bash

复制

python image_process.py
一键获取完整项目代码
看到两行提示:

✅ 已生成:D:\Demo\robot_enhanced.jpg

同时弹出两个窗口:
左边是原图,右边是“切头+提亮”后的效果。
按任意键 关闭窗口,实验完成!

4. 效果对比
表格

复制

原图 处理后
完整机器人,整体偏灰 仅左上角,金属质感变亮,边缘对比强烈
文件 1.2 MB 文件 0.3 MB(体积也小了)
5. 知识点复盘
表格

复制

术语 一句话解释
像素 图像最小色点,坐标 (x,y) 对应一个颜色值
图像矩阵 OpenCV 中一张图就是 numpy 三维数组
裁剪 本质是 Python 切片 img[y1:y2, x1:x2]
对比度增强 cv2.convertScaleAbs(src, alpha, beta)
通道顺序 OpenCV 默认 BGR,不是 RGB!
6. 想再玩点花样?
表格

复制

需求 改哪一行
裁剪正中 200×200 roi = img[h//2-100:h//2+100, w//2-100:w//2+100]
黑白复古风 加一行 gray = cv2.cvtColor(enhanced, cv2.COLOR_BGR2GRAY)
一键九宫格 写循环把原图切 3×3 保存 9 张
批量文件夹 用 glob 遍历 *.jpg 即可
7. 常见报错速查
表格

复制

报错 原因 解决
cv2.error: (-215:Assertion failed) 路径中文或图片没读到 换英文路径,确认 robot.jpg 存在
ModuleNotFoundError: cv2 装到了别的 Python 用 where python / which python 看路径,重装盘
弹窗闪退 没加 waitKey(0) 把代码抄全
8. 总结
今天我们只做了两件事:

用切片裁剪图像;

用 convertScaleAbs 提亮对比度。

但已经覆盖了 数字图像处理 7 大环节 里的
“图像采集 → 图像增强 → 图像表示” 三步。

下一步你可以挑战:

边缘检测 → cv2.Canny

人脸检测 → cv2.CascadeClassifier

磨皮美颜 → 双边滤波 cv2.bilateralFilter

9. 源码下载
懒得敲字?
GitHub 仓库(含 robot.jpg 与完整代码):
👉 https://github.com/yourname/opencv-10min-demo
Star 不迷路,后续更新九宫格、滤镜、动图生成!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 12:03:50

纯文本任务体验结果

目的和要求理解大语言模型的基本工作原理,包括其训练方式和生成机制。熟悉国内外主流大语言模型的特点、应用场景及技术差异。通过实际体验,掌握不同模型在文本生成、逻辑推理、多模态任务等方面的表现。实验准备大语言模型是通过海量文本数据训练的深度…

作者头像 李华
网站建设 2026/4/16 10:20:47

2025 AI技术竞赛:GPT-5.2与Gemini 3的深度对决,谁能引领未来?

2025年,人工智能领域的两大巨头迎来了他们最新的技术成果——OpenAI 发布的 GPT-5.2 和 Google 推出的 Gemini 3。这两款先进的AI模型在多个层面上都展现了强大的能力,但它们的定位、技术创新和应用场景却有着明显的差异。 GPT-5.2 和 Gemini 3 都宣称要…

作者头像 李华
网站建设 2026/4/16 10:17:57

基于 HTML5 Canvas 的终端日志流可视化实现(支持多 Pane / 运维模式)

在日常运维、演示或监控系统中,我们经常需要一种**“像真实终端一样滚动的日志界面”**,用于: 运维大屏 / NOC 展示Demo / 产品演示系统状态背景动画DevOps / 云原生场景模拟 本文将完整解析一个基于 HTML Canvas 的终端日志流可视化方案&am…

作者头像 李华
网站建设 2026/4/15 18:57:09

深入理解C#抽象类与虚方法

抽象类和虚方法一,抽象类1,抽象类: 用于提供类的部分成员实现 动态多态表现:抽象 2,抽象类包含抽象方法也可以是普通方法 ,如果抽象方法不用去实现,谁继承这个抽象谁去实现抽象方法3&#x…

作者头像 李华
网站建设 2026/4/16 10:21:46

国密内网IP是什么?

国密内网IP证书的定义国密内网IP证书是一种基于国家密码管理局(SM系列算法)标准的内网IP地址加密证书,主要用于保障内网通信的安全性和身份认证。这类证书采用国产密码算法(如SM2、SM3、SM4),符合国家信息安…

作者头像 李华