读取一个文件夹中的所有图片画出他们的频谱图再存入一个文件夹中

这次是一个很简单的代码,用途如标题

folder_path是读取的路径

os.path.join后面的括号中第一个是保存路径

都能看得懂的吧?

import numpy as np
import os
import cv2
import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['SimHei']  # 设置中文字体


# 定义绘制频谱图的函数
def plot_spectrum(image, title,_path):
    f = np.fft.fft2(image)
    fshift = np.fft.fftshift(f)
    magnitude_spectrum = 20*np.log(np.abs(fshift))
    plt.subplot(121), plt.imshow(magnitude_spectrum, cmap='gray')
    plt.title(title), plt.xticks([]), plt.yticks([])
    plt.subplot(122), plt.imshow(image, cmap='gray')
    plt.title('输入图像'), plt.xticks([]),  plt.yticks([])
    plt.savefig(os.path.join("D:\Signal_and_System_PBL\salt_pepper_picture\\butterworth", title + '_spectrum.png'))
    plt.close()

# 定义读取文件夹中所有图片的函数
def read_images_from_folder(folder_path):
    images = []
    for filename in os.listdir(folder_path):
        if filename.endswith('.jpg') or filename.endswith('.png'):
            img = cv2.imread(os.path.join(folder_path, filename), cv2.IMREAD_GRAYSCALE)
            if img is not None:
                images.append(img)
    return images

# 读取文件夹中的所有图片
folder_path ="D:\Signal_and_System_PBL\salt_pepper_picture\\butterworth"
images = read_images_from_folder(folder_path)

# 对每张图片绘制频谱图并保存
for i, image in enumerate(images):
    title = 'image_{}'.format(i)
    plot_spectrum(image, title, folder_path)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值