Python如何去除图片干扰代码示例

 更新时间:2025年06月17日 11:47:43   作者:detayun  
图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,这篇文章主要介绍了Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

在Python中去除图片干扰,需根据干扰类型(如噪声、特定物体、强光等)选择合适的方法。以下是分场景解决方案及代码示例:

一、噪声去除

1. 高斯噪声(像素值正态分布扰动)

  • 方法:高斯滤波、双边滤波、小波变换
  • 代码示例(OpenCV)
    import cv2
    import numpy as np
    
    # 读取图像并添加高斯噪声
    image = cv2.imread('noisy_image.jpg')
    noise = np.random.normal(0, 25, image.shape).astype(np.uint8)
    noisy_image = cv2.add(image, noise)
    
    # 高斯滤波去噪
    gaussian_filtered = cv2.GaussianBlur(noisy_image, (5, 5), 0)
    
    # 双边滤波(保留边缘)
    bilateral_filtered = cv2.bilateralFilter(noisy_image, d=9, sigmaColor=75, sigmaSpace=75)
    
    cv2.imshow('Original', image)
    cv2.imshow('Gaussian Filtered', gaussian_filtered)
    cv2.imshow('Bilateral Filtered', bilateral_filtered)
    cv2.waitKey(0)
    

2. 椒盐噪声(随机黑白像素点)

  • 方法:中值滤波
  • 代码示例(OpenCV)
    # 添加椒盐噪声(示例)
    x = image.reshape(-1)
    SNR = 0.85
    noise_num = int(x.size * (1 - SNR))
    random_indices = np.random.choice(x.size, noise_num, replace=False)
    x[random_indices] = np.random.choice([0, 255], noise_num)
    noisy_image = x.reshape(image.shape)
    
    # 中值滤波去噪
    median_filtered = cv2.medianBlur(noisy_image, 5)
    

3. 复杂噪声(如伪影)

  • 方法:非局部均值去噪(NLM)
  • 代码示例(Scikit-image)
    from skimage import io, img_as_float
    from skimage.restoration import denoise_nl_means
    
    image = img_as_float(io.imread('noisy_image.jpg'))
    denoised = denoise_nl_means(image, h=0.1, fast_mode=True, patch_size=5, patch_distance=3)
    

二、特定干扰去除

1. 干扰线(如扫描文档中的横线)

  • 方法:二值化 + 邻域分析
  • 代码示例(Pillow)
    from PIL import Image, ImageFilter
    
    def remove_lines(image_path, threshold=128):
        image = Image.open(image_path).convert('L')  # 转为灰度
        binarized = image.point(lambda x: 0 if x < threshold else 255, '1')
        clean = binarized.copy()
        width, height = binarized.size
    
        for y in range(1, height-1):
            for x in range(1, width-1):
                if binarized.getpixel((x, y)) == 0:
                    neighbors = [binarized.getpixel((x-1, y)), binarized.getpixel((x+1, y)),
                                 binarized.getpixel((x, y-1)), binarized.getpixel((x, y+1))]
                    if neighbors.count(0) >= 2:
                        clean.putpixel((x, y), 255)
        return clean
    
    cleaned_image = remove_lines('document.jpg')
    cleaned_image.save('cleaned_document.jpg')
    

2. 强光干扰(过曝区域)

  • 方法:颜色空间转换 + 阈值调整
  • 代码示例(OpenCV)
    import cv2
    import numpy as np
    
    image = cv2.imread('overexposed.jpg')
    hsv = cv2.cvtColor(image, cv2.COLOR_BGR2HSV)
    lower = np.array([0, 0, 200])  # V通道阈值
    upper = np.array([180, 255, 255])
    mask = cv2.inRange(hsv, lower, upper)
    
    # 降低过曝区域亮度
    image[mask != 0] = cv2.add(image[mask != 0], (0, 0, -80))
    cv2.imwrite('corrected.jpg', image)
    

三、深度学习进阶方案

对于复杂场景(如混合噪声、纹理干扰),可使用预训练模型(如U-Net、DnCNN):

import torch
from torchvision import models

# 加载预训练去噪模型(示例)
model = models.DnCNN().eval()
model.load_state_dict(torch.load('dncnn_pretrained.pth'))

# 预处理输入
input_tensor = preprocess(noisy_image)  # 需自定义预处理函数
with torch.no_grad():
    output = model(input_tensor)
denoised_image = postprocess(output)  # 自定义后处理函数

四、方法选择建议

  • 快速去噪:优先使用OpenCV/Pillow的内置滤波器(如cv2.medianBlur)。
  • 保留细节:选择双边滤波或小波变换。
  • 复杂噪声:尝试Scikit-image的非局部均值或深度学习模型。
  • 特定干扰:结合二值化、形态学操作或自定义像素分析逻辑。

通过调整滤波器参数(如核大小、阈值)或模型超参数,可进一步优化去噪效果。

到此这篇关于Python如何去除图片干扰的文章就介绍到这了,更多相关Python去除图片干扰内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 如何用python和java分别写出10道经典题(含代码)

    如何用python和java分别写出10道经典题(含代码)

    Python与Java在语言特性、性能和应用场景上各有优势,下面这篇文章主要介绍了如何用python和java分别写出10道经典题的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2026-05-05
  • Python计算一个点到所有点的欧式距离实现方法

    Python计算一个点到所有点的欧式距离实现方法

    今天小编就为大家分享一篇Python计算一个点到所有点的欧式距离实现方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-07-07
  • 使用Django中的filter方法进行数据查询的基本操作

    使用Django中的filter方法进行数据查询的基本操作

    在 Django 中,QuerySet 的 filter() 方法是一个强大的工具,用于从数据库中检索数据并根据指定的条件进行筛选,在本文中,我们将介绍如何使用 filter() 方法来执行各种类型的数据查询操作,需要的朋友可以参考下
    2024-05-05
  • Django项目创建的图文教程

    Django项目创建的图文教程

    本文主要介绍了Django项目创建的图文教程,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • pycharm配置Qt Designer工具的图文教程

    pycharm配置Qt Designer工具的图文教程

    本文主要介绍了pycharm配置Qt Designer工具的图文教程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • 解决Python中pandas读取*.csv文件出现编码问题

    解决Python中pandas读取*.csv文件出现编码问题

    很多朋友在使用Python中pandas读取csv文件时,出现编码格式问题,接下来通过本文给大家分享解决Python中pandas读取*.csv文件出现编码问题,需要的朋友可以参考下
    2019-07-07
  • 在Python中将函数作为另一个函数的参数传入并调用的方法

    在Python中将函数作为另一个函数的参数传入并调用的方法

    今天小编就为大家分享一篇在Python中将函数作为另一个函数的参数传入并调用的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-01-01
  • Python实现普通图片转ico图标的方法详解

    Python实现普通图片转ico图标的方法详解

    ICO是一种图标文件格式,图标文件可以存储单个图案、多尺寸、多色板的图标文件。本文将利用Python实现普通图片转ico图标,感兴趣的小伙伴可以了解一下
    2022-11-11
  • Pytorch实现ResNet网络之Residual Block残差块

    Pytorch实现ResNet网络之Residual Block残差块

    这篇文章主要为大家介绍了Pytorch实现ResNet网络之Residual Block残差块实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • Python操作Markdown格式文件的全攻略

    Python操作Markdown格式文件的全攻略

    Markdown 是一种轻量级标记语言,用于以纯文本形式编写格式化文档,广泛应用于技术文档,博客,笔记管理以及学术写作等场景,下面我们就来看看如何使用Python操作Markdown格式文件吧
    2026-03-03

最新评论