使用python 对验证码图片进行降噪处理


Posted in Python onDecember 18, 2019

首先贴一张验证码上来做案例:

使用python 对验证码图片进行降噪处理

第一步先通过二值化处理把干扰线去掉:

from PIL import Image
 
# 二值化处理
def two_value():
  for i in range(1,5):
    # 打开文件夹中的图片
    image=Image.open('./Img/'+str(i)+'.jpg')
    # 灰度图
    lim=image.convert('L')
    # 灰度阈值设为165,低于这个值的点全部填白色
    threshold=165
    table=[]
    
    for j in range(256):
      if j<threshold:
        table.append(0)
      else:
        table.append(1)
 
    bim=lim.point(table,'1')
    bim.save('./Img2/'+str(i)+'.jpg')
 
two_value()

运行结果图如下:

使用python 对验证码图片进行降噪处理

然后对黑白图片进行降噪,去掉那些单独的黑色像素点:

from PIL import Image
 
# 去除干扰线
im = Image.open('./Img2/1.jpg')
# 图像二值化
data = im.getdata()
w,h = im.size
black_point = 0
 
for x in range(1,w-1):
  for y in range(1,h-1):
    mid_pixel = data[w*y+x] # 中央像素点像素值
    if mid_pixel <50: # 找出上下左右四个方向像素点像素值
      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 <10:
        black_point += 1
      if left_pixel <10:
        black_point += 1
      if down_pixel <10:
        black_point += 1
      if right_pixel <10:
        black_point += 1
      if black_point <1:
        im.putpixel((x,y),255)
      # print(black_point)
      black_point = 0
 
im.save('xxxx.jpg')

运行结果如下图所示:

使用python 对验证码图片进行降噪处理

最后对边框上附着的黑色像素点进行消除:

from PIL import Image
 
# 去除干扰线
im = Image.open('./Img2/1.jpg')
# 图像二值化
data = im.getdata()
w,h = im.size
black_point = 0
 
for x in range(1,w-1):
  for y in range(1,h-1):
    if x<2 or y<2 :
      im.putpixel((x-1, y-1), 255)
    if x>w-3 or y>h-3:
      im.putpixel((x+1 , y+1 ), 255)
 
im.save('xxx.jpg')

运行结果:

使用python 对验证码图片进行降噪处理

以上这篇使用python 对验证码图片进行降噪处理就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python读写Excel文件的实例
Nov 01 Python
python实现可将字符转换成大写的tcp服务器实例
Apr 29 Python
Python 文件处理注意事项总结
Apr 10 Python
Python中django学习心得
Dec 06 Python
Falsk 与 Django 过滤器的使用与区别详解
Jun 04 Python
Python将文字转成语音并读出来的实例详解
Jul 15 Python
django中间键重定向实例方法
Nov 10 Python
Python Django view 两种return的实现方式
Mar 16 Python
python实现TCP文件传输
Mar 20 Python
重写django的model下的objects模型管理器方式
May 15 Python
Scrapy-Redis之RedisSpider与RedisCrawlSpider详解
Nov 18 Python
python绘制简单直方图(质量分布图)的方法
Apr 21 Python
如何使用Python多线程测试并发漏洞
Dec 18 #Python
Python实现图像去噪方式(中值去噪和均值去噪)
Dec 18 #Python
python 中值滤波,椒盐去噪,图片增强实例
Dec 18 #Python
Django中使用MySQL5.5的教程
Dec 18 #Python
Python hashlib加密模块常用方法解析
Dec 18 #Python
Python实现中值滤波去噪方式
Dec 18 #Python
详解Python中字符串前“b”,“r”,“u”,“f”的作用
Dec 18 #Python
You might like
PHP 和 MySQL 基础教程(一)
2006/10/09 PHP
查找mysql字段中固定字符串并替换的几个方法
2012/09/23 PHP
解析Extjs与php数据交互(增删查改)
2013/06/25 PHP
php mailer类调用远程SMTP服务器发送邮件实现方法
2016/03/04 PHP
PHP单例模式实例分析【防继承,防克隆操作】
2019/05/22 PHP
网页右键ie不支持event.preventDefault和event.returnValue (需要加window)
2013/02/22 Javascript
JavaScript利用正则表达式去除日期中的“-”
2014/07/01 Javascript
JS实现的多张图片轮流播放幻灯片效果
2016/07/22 Javascript
js评分组件使用详解
2017/06/06 Javascript
Vue from-validate 表单验证的示例代码
2017/09/26 Javascript
vue 路由缓存 路由嵌套 路由守卫 监听物理返回操作
2020/08/06 Javascript
JavaScript用document.write()输出换行的示例代码
2020/11/26 Javascript
[38:30]2014 DOTA2国际邀请赛中国区预选赛 LGD-GAMING VS CIS 第一场2
2014/05/24 DOTA
[07:20]2014DOTA2西雅图国际邀请赛 选手讲解积分赛第二天
2014/07/11 DOTA
python生成验证码图片代码分享
2016/01/28 Python
Python读写Json涉及到中文的处理方法
2016/09/12 Python
Python标准库sched模块使用指南
2017/07/06 Python
Python常见读写文件操作实例总结【文本、json、csv、pdf等】
2019/04/15 Python
python3中类的继承以及self和super的区别详解
2019/06/26 Python
Python 自动登录淘宝并保存登录信息的方法
2019/09/04 Python
python识别验证码图片实例详解
2020/02/17 Python
python爬虫使用requests发送post请求示例详解
2020/08/05 Python
python开根号实例讲解
2020/08/30 Python
浅谈CSS3 box-sizing 属性 有趣的盒模型
2019/04/02 HTML / CSS
波兰在线体育用品商店:Hop-Sport.pl
2019/07/23 全球购物
趣天网日本站:Qoo10 JP
2019/09/18 全球购物
华硕新加坡官方网上商店:ASUS Singapore
2020/07/09 全球购物
校园联欢晚会主持词
2014/03/17 职场文书
党员领导干部承诺书
2014/05/28 职场文书
优秀党员推荐材料
2014/12/18 职场文书
百万英镑观后感
2015/06/09 职场文书
民事调解协议书
2016/03/21 职场文书
25句企业管理语录:助你迅速打开思路,句句经典!
2020/01/14 职场文书
python自然语言处理之字典树知识总结
2021/04/25 Python
SQLServer中JSON文档型数据的查询问题解决
2021/06/27 SQL Server
嵌入式Redis服务器在Spring Boot测试中的使用教程
2021/07/21 Redis