图像处理技术与应用(一)

图像处理技术与应用入门

使用 skimage 进行图像读取和显示

skimage库(Scikit-image)提供了一个强大的工具集,用于执行各种图像处理任务。以下是如何使用skimage读取和显示图像的基本示例:

python 复制代码
from skimage import io

img = io.imread("dd.jpg", as_gray=True)

io.imshow(img)

io.show()

读取一个名为dd.jpg的图像文件,并以灰度模式显示它。

原图

灰度图像

使用 skimage读取内置测试图像****

skimage库提供了一些内置的测试图像,可以直接使用:

python 复制代码
from skimage import data

img = data.hubble_deep_field()

io.imshow(img)

显示了Hubble深空图像。

读取图像并保存

python 复制代码
from skimage import data_dir,data,io

# img1 = data.hubble_deep_field()

img2 = io.imread('C:/Users/14919/OneDrive/Pictures/Screenshot_20230802_150439.jpg')

# # print(img2)

io.imshow(img2)

io.show()

io.imsave('C:/Users/14919/OneDrive/Desktop/图像处理-工坊/11.jpg',img)

使用 PIL** skimage复制图像到新文件夹**

Python Imaging Library(PIL)的Image模块可以与skimage结合使用,以复制图像到新文件夹:

python 复制代码
from PIL import Image

import os

from skimage import io



# 图片存储的文件夹路径

folder_path = 'C:/Users/14919/OneDrive/Desktop/图像处理-工坊'

 

# 用来保存图片的文件夹路径

output_folder_path = 'C:/Users/14919/OneDrive/Desktop/图像处理-工坊/aa'

 

# 确保输出文件夹存在

if not os.path.exists(output_folder_path):

    os.makedirs(output_folder_path)



# 遍历文件夹中的所有图片

for filename in os.listdir(folder_path):

    if filename.endswith(('.png', '.jpg', '.jpeg', '.bmp', '.gif')):

        

        # 打开图片

        img = Image.open(os.path.join(folder_path, filename))

 

        # 保存图片到输出文件夹,同时保留原有文件名

        img.save(os.path.join(output_folder_path, filename))

这段代码将遍历指定文件夹中的所有图片,并将它们保存到另一个文件夹中。

使用matplotlib和skimage分析图像属性

matplotlib库可以与skimage一起使用,以分析图像的属性:

python 复制代码
import matplotlib.pyplot as plt

from skimage import io



img = io.imread("cc.jpg")

io.imshow(img)

plt.axis('off')



print('图片的类型是:',type(img))# 显示类型

print('图片的尺寸是:',img.shape)# 显示尺寸

print('图片的宽度是:',img.shape[0])# 图片宽度

print('图片的高度是:',img.shape[1])# 图片高度

print('图片的通道数是:',img.shape[2])# 图片通道数

print('图像总像素个数是:',img.size) # 显示总像素个数

print('图象的最大像素值是:',img.max())# 最大像素值

print('图像最小像素值是:',img.min())# 最小像素值

print('图像像素平均值是:',img.mean())# 像素平均值

显示了图像,还输出了关于图像的重要统计信息,如尺寸、像素值等

分段写出代码效果会更好

使用 cv2 进行图像处理

cv2是OpenCV库的Python接口,它提供了广泛的图像处理和计算机视觉功能。以下是如何使用cv2调整图像大小和显示不同颜色通道的示例:

python 复制代码
import cv2



img = cv2.imread('aa.jpg')



#调整图像大小为300x300

img = cv2.resize(img, (300, 300))

cv2.imshow("img show", img)



# 读取蓝色通道,最后一个值为0

b = img[:, :, 0]

# 读取绿色通道,最后一个值为 1

g = img[:, :, 1]

# 读取红色通道,最后一个值为 2

r = img[:, :, 2]



# 分别显示

cv2.imshow("b", b)

cv2.imshow("g", g)

cv2.imshow("r", r)



cv2.waitKey()

cv2.destroyAllWindows()

读取图像、调整其大小,并分别显示其红色、绿色和蓝色通道。

r为红色通道,下标值为2

g为绿色通道,下标值为1

b为蓝色通道,下标值为0

相关推荐
hans汉斯19 小时前
【软件工程与应用】平移置换搬迁系统设计与实现
数据库·人工智能·系统架构·软件工程·汉斯出版社·软件工程与应用
啊阿狸不会拉杆19 小时前
《数字图像处理 》 第 1 章-绪论
图像处理·python·opencv·算法·数字图像处理
许泽宇的技术分享19 小时前
Sim.ai:开源AI工作流编排平台的技术革命——从可视化设计到生产级部署的完整实践
人工智能·开源
智驱力人工智能19 小时前
加油站静电夹检测 视觉分析技术的安全赋能与实践 静电夹检测 加油站静电夹状态监测 静电接地报警器检测
人工智能·深度学习·算法·安全·yolo·边缘计算
星环之光19 小时前
关于CNN(卷积神经网络)
人工智能·神经网络·cnn
阿里云云原生19 小时前
LoongSuite:解决 WebSocket 全链路可观测性难题,赋能 AI 应用的实时链路追踪
人工智能·websocket·网络协议·阿里云·云原生·可观测
拓端研究室19 小时前
专题:2025医疗行业核心洞察报告:AI医疗、医疗器械、投融资与新药|附380+份报告PDF、数据、可视化模板汇总下载
大数据·人工智能
python-码博士19 小时前
关于sklearn中StandardScaler的使用方式
人工智能·python·sklearn
Java后端的Ai之路19 小时前
【分析式AI】-分类与回归的区别以及内联
人工智能·分类·数据挖掘·回归·aigc
UpYoung!19 小时前
【截图与贴图工具推荐】截图与贴图工具——PixPin保姆级详细图文下载安装指南
图像处理·贴图·实用工具·图像编辑·截图工具·开源工具·运维必备