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

图像处理技术与应用入门

使用 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

相关推荐
只说证事38 分钟前
2025年数字公共治理专业重点学什么内容?(详细指南)
人工智能
LeeZhao@39 分钟前
【AI推理部署】Docker篇04—Docker自动构建镜像
人工智能·docker·容器
程思扬43 分钟前
利用JSONCrack与cpolar提升数据可视化及跨团队协作效率
网络·人工智能·经验分享·docker·信息可视化·容器·架构
南方者1 小时前
它的 AI Agent 凭什么能擦出火花?!
人工智能·ai编程
心动啊1211 小时前
深度神经网络1——梯度问题+标签数不够问题
人工智能·神经网络·dnn
南方者1 小时前
基于Amazon Bedrock Agent 的两个服务示例的完整流程与详细内容,包含技术架构、实现细节、交互逻辑及扩展能力
人工智能·ai编程·敏捷开发
小王爱学人工智能1 小时前
OpenCV一些进阶操作
人工智能·opencv·计算机视觉
新智元1 小时前
起猛了!这个国家任命 AI 为「部长」:全球首个,手握实权,招标 100% 透明
人工智能·openai
张较瘦_1 小时前
[论文阅读] 人工智能 + 软件工程 | 大语言模型驱动的多来源漏洞影响库识别研究解析
论文阅读·人工智能·语言模型
艾醒1 小时前
大模型面试题剖析:RAG中的文本分割策略
人工智能·算法