图像处理1,灰度,data,for循环批处理图片,图片属性查看,图片单通道查看,椒盐噪声的生成,滤波处理,图像分割

图像处理1

灰度处理

py 复制代码
from skimage import io
a = 'tuxian.jpg'
img = io.imread(a,as_gray=True)
io.imshow(img)
io.show()

这段代码使用Python中的skimage库来读取名为"tuxian.jpg"的图像文件赋值给a,并将其以灰度图像的形式加载到变量img中。然后使用skimage库中的io.imshow()函数显示图像,最后使用io.show()函数将图像显示在屏幕上。

data库的使用

py 复制代码
from skimage import io, data
img = data.chelsea()
io.imshow(img)
io.show()

这里使用了data.chelsea()将data库中的小猫图片调用了出来

py 复制代码
from skimage import data_dir
print(data_dir)

这段代码使用Python中的skimage库,并导入其中的data_dir模块。然后使用print语句打印出data_dir模块的值,该值表示skimage库中存储数据文件的目录路径。

py 复制代码
from skimage import io, data
img = data.chelsea()
io.imshow(img)
io.imsave('C:/Users/daiyo/Desktop/jupyter库/工坊/xiaomao.jpg',img)
io.show()

此代码与上面的

py 复制代码
from skimage import io, data
img = data.chelsea()
io.imshow(img)
io.show()

效果一样

for循环批处理图像

py 复制代码
import os
from skimage import io

folder_path = 'C:/Users/daiyo/Desktop/jupyter库/工坊/图像'
save_folder_path = 'C:/Users/daiyo/Desktop/jupyter库/工坊/图像/savepng'

img_list = []

# 遍历文件夹中的所有文件
for filename in os.listdir(folder_path):
    if filename.endswith('.jpg'):
        img_path = os.path.join(folder_path, filename)
        img = io.imread(img_path)
        img_list.append(img)

# 保存图像为png格式
for i, img in enumerate(img_list):
    save_path = os.path.join(save_folder_path, f'image_{i}.png')  # 构造保存路径
    io.imsave(save_path, img)
  1. 首先导入必要的模块
  2. 设置源文件夹和目标文件夹的路径:
    folder_path:包含原始 .jpg 图像的文件夹路径。
    save_folder_path:将保存新的 .png 图像的目标文件夹路径。
  3. 初始化图像列表:
    创建一个空列表 img_list,用来存储从文件夹中读取的图像数据。
  4. 读取并存储图像数据:
    使用 os.listdir(folder_path) 遍历指定文件夹中的所有文件。
    对于每个文件,检查文件名是否以 .jpg 结尾。如果是,执行以下操作:
    使用 os.path.join(folder_path, filename) 构造完整的文件路径。
    使用 io.imread(img_path) 读取图像文件,并将读取的图像数据存储到变量 img 中。
    将 img 添加到列表 img_list 中。
  5. 保存图像为 PNG 格式:
    代码遍历img_list列表中的每个图像,使用enumerate()函数获取图像在列表中的索引i。
    然后构造保存路径save_path为save_folder_path下的'image_i.png',其中i为图像在列表中的索引。最后使用io.imsave()函数将每个图像保存为png格式文件,保存在指定的文件夹路径下,文件名为'image_i.png'。

对图像属性的查看

图片类型

py 复制代码
from skimage import io
a = 'tuxian.jpg'
img = io.imread('tuxian.jpg')
# io.imshow(img)
print("图片类型是",type(a))

图片尺寸

图片宽度

图像高度

通道数

总像素个数

最大像素值

最小像素值,像素平均值


图像点像素值

py 复制代码
from skimage import io
img = io.imread('tuxian.jpg')
place = img[30, 40]
print(place)

for循环分别显示图像rgb通道

py 复制代码
import cv2
img = cv2.imread("tuxian.jpg")
cv2.imshow("one1",img)
b = img[:,:,0]
g = img[:, :, 1]  
r = img[:, :, 2] 
cv2.imshow("b",b)
cv2.imshow("g", g)  
cv2.imshow("r", r) 
# 等待用户点击关闭窗口
while True:
    if cv2.waitKey(1) & 0xFF == ord('q'):
        break

cv2.destroyAllWindows()

这段代码的功能是显示原始图像以及其分离的蓝色、绿色和红色通道的图像,并等待用户按下"q"键来关闭显示的窗口。

椒盐噪声的生成

py 复制代码
from skimage import io
import numpy as np

img = io.imread('tuxian.jpg')
rows, cols, dims = img.shape

for i in range(5000):
    x = np.random.randint(0, rows)
    y = np.random.randint(0, cols)
    img[x, y, :] = 255

io.imshow(img)
io.imsave('after.jpg',img)
io.show()

这段代码的功能是在读取的图像上随机选取5000个像素位置,并将这些位置的像素值设置为白色,然后显示修改后的图像并保存为新的图像文件。

中值滤波处理

py 复制代码
img2 = io.imread('after.jpg')
denoised_image = cv2.medianBlur(img2, 3)  # 3表示核的大小,可以根据需要调整
io.imshow(denoised_image)
io.show()

使用OpenCV库(cv2)中的medianBlur()函数对图像img2进行中值滤波处理,其中参数3表示核的大小。中值滤波是一种常用的去噪方法,可以有效地去除椒盐噪声。

高斯模糊处理

py 复制代码
img2 = io.imread('after.jpg')
blurred_image = cv2.GaussianBlur(img2, (5, 5), 0)
io.imshow(blurred_image)
io.show()

使用OpenCV库(cv2)中的GaussianBlur()函数对图像img2进行高斯模糊处理。函数的第一个参数是输入图像,第二个参数是高斯核的大小,这里是(5, 5),第三个参数是高斯核的标准差,这里是0。高斯模糊是一种常用的去噪方法,可以平滑图像并降低噪声。

图像切割

py 复制代码
from skimage import io
img = io.imread('羊.jpg')
roi = img[382:1075,810:1755,:]
# io.imshow(img)
io.imshow(roi)
io.show()

使用skimage库中的io模块读取了名为"羊.jpg"的图像,并将其存储在变量img中。然后,通过切片操作,选择了图像img中指定区域的感兴趣区域(ROI),即从382行到1075行、从810列到1755列的部分图像,并将其存储在变量roi中。

接着使用io.imshow()函数显示了选定的感兴趣区域roi,并调用io.show()函数展示了这个部分图像。

相关推荐
赵谨言3 分钟前
基于python 微信小程序的医院就诊小程序
经验分享·python·毕业设计
1.01^100017 分钟前
[1111].集成开发工具Pycharm安装与使用
python·pycharm
HEX9CF18 分钟前
【Django】测试带有 CSRF 验证的 POST 表单 API 报错:Forbidden (CSRF cookie not set.)
python·django·csrf
西西弗Sisyphus41 分钟前
基于推理的目标检测 DetGPT
目标检测·计算机视觉
凡人的AI工具箱1 小时前
每天40分玩转Django:实操多语言博客
人工智能·后端·python·django·sqlite
Py办公羊大侠1 小时前
Excel批量设置行高,Excel表格设置自动换行后打印显示不全,Excel表格设置最合适的行高后打印显示不全,完美解决方案!!!
python·excel·打印·openpyxl·自动换行·显示不全
PieroPc1 小时前
Python tkinter写的《电脑装配单》和 Html版 可打印 可导出 excel 文件
python·html·电脑
Cachel wood1 小时前
Django REST framework (DRF)中的api_view和APIView权限控制
javascript·vue.js·后端·python·ui·django·前端框架
伊一大数据&人工智能学习日志1 小时前
OpenCV计算机视觉 01 图像与视频的读取操作&颜色通道
人工智能·opencv·计算机视觉
暮色尽染1 小时前
Python 正则表达式
开发语言·python