python 图片去噪的方法示例

作者:qq_41895190 时间:2021-12-10 19:42:25 

图像可能在生成、传输或者采集过程中夹带了噪声,去噪声是图像处理中常用的手法。通常去噪声用滤波的方法,比如中值滤波、均值滤波。但是那样的算法不适合用在处理字符这样目标狭长的图像中,因为在滤波的过程中很有可能会去掉字符本身的像素。

一个采用的是去除杂点的方法来进行去噪声处理的。具体算法如下:扫描整个图像,当发现一个黑色点的时候,就考察和该黑色点间接或者直接相连接的黑色点的个数有多少,如果大于一定的值,那就说明该点不是离散点,否则就是离散点,把它去掉。在考察相连的黑色点的时候用的是递归的方法。此处,我简单的用python实现了,大家可以参考以下。


#coding=utf-8
"""
造物奇迹QQ2737499951
"""
import cv2
import numpy as np
from matplotlib import pyplot as plt
from PIL import Image,ImageEnhance,ImageFilter

img_name = 'test.jpg'
#去除干扰线
im = Image.open(img_name)
#图像二值化
enhancer = ImageEnhance.Contrast(im)
im = enhancer.enhance(2)
im = im.convert('1')
data = im.getdata()
w,h = im.size
#im.show()
black_point = 0
for x in xrange(1,w-1):
 for y in xrange(1,h-1):
   mid_pixel = data[w*y+x] #中央像素点像素值
   if mid_pixel == 0: #找出上下左右四个方向像素点像素值
     top_pixel = data[w*(y-1)+x]
     left_pixel = data[w*y+(x-1)]
     down_pixel = data[w*(y+1)+x]
     right_pixel = data[w*y+(x+1)]

#判断上下左右的黑色像素点总个数
     if top_pixel == 0:
       black_point += 1
     if left_pixel == 0:
       black_point += 1
     if down_pixel == 0:
       black_point += 1
     if right_pixel == 0:
       black_point += 1
     if black_point >= 3:
       im.putpixel((x,y),0)
     #print black_point
     black_point = 0
im.show()

来源:https://blog.csdn.net/qq_41895190/article/details/82781077

标签:python,图片去噪
0
投稿

猜你喜欢

  • Tensorflow读取并输出已保存模型的权重数值方式

    2023-09-15 10:07:49
  • Django 博客实现简单的全文搜索的示例代码

    2023-12-07 10:09:19
  • 在Python中通过threshold创建mask方式

    2022-10-22 16:52:49
  • Python numpy.transpose使用详解

    2021-10-17 16:51:10
  • MySql数据库备份的几种方式

    2024-01-17 03:15:05
  • 基于pandas将类别属性转化为数值属性的方法

    2021-11-24 07:15:16
  • 老生常谈js中0到底是 true 还是 false

    2024-05-11 09:44:12
  • php 常用字符串函数总结

    2024-06-05 09:47:33
  • python实现稀疏矩阵示例代码

    2023-10-03 02:37:18
  • python必备库Matplotlib画图神器

    2021-03-29 21:16:08
  • 基于selenium及python实现下拉选项定位select

    2023-01-13 12:17:48
  • 简单了解Django ORM常用字段类型及参数配置

    2022-11-03 09:11:38
  • python 合并列表的八种方法

    2022-06-10 10:07:29
  • 关于Python dict存中文字符dumps()的问题

    2022-08-22 17:53:17
  • 数据结构-树(三):多路搜索树B树、B+树

    2024-01-27 01:21:43
  • 基于PyQt5制作一个群发邮件工具

    2022-09-04 01:46:46
  • Python unittest 自动识别并执行测试用例方式

    2023-08-14 07:09:39
  • python 实现mysql自动增删分区的方法

    2024-01-14 17:09:58
  • eWebEditor不支持IE8的解决方法

    2009-11-02 10:59:00
  • 解析Anaconda创建python虚拟环境的问题

    2023-08-01 03:58:13
  • asp之家 网络编程 m.aspxhome.com