百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

基于python简单图像处理,识别验证码

off999 2024-10-23 12:52 39 浏览 0 评论

基本识别原理概述:

1、每一幅图像在构成上,都是由一个个像素组成的矩阵,每一个像素为单元格。

2、 彩色图像的像素的由三原色(红,绿,蓝)构成元组,灰度图像的像素是一个单值,每个像素的值范围为(0,255)。

问题来源

某系统门户登陆界面如下:

现在我们要实现自动的验证码识别。

图像特征

首先,我们仔细观察下这个验证码图像,可以发现一些固定特征:

1、验证码中的字符数始终为6,并且是灰度图像。

2、字符间的间隔看起来每次都一样。

3、 每个字符都是完全定义的。

4、图像有许多杂散的黑暗像素,以及穿过图像的线条作为干扰因素。

图像分析

所以我最终下载了一个这样的图像,并使用一个工具(binary-image)以二进制形式可视化图像(0表示黑色,1表示白色像素)。

我的观察没错,图像尺寸为45x180,每个字符分配30个像素的空间来适配,从而使它们间隔比较均匀。

因此,取得了验证码识别路上的第一步,结果:

把图像裁剪成6个不同的部分,每个部分的宽度为30像素。

python图像裁剪

我们璇儿Python作为原型语言,因为它的库最容易使用和部署。

经过简单搜索,我找到了PIL库。还用到了Image模块,用来操作图像进行字符裁剪并将图像作为加载为数字矩阵。

字符部分裁剪

图像裁剪的语法是:

from PIL import Image

image = Image.open("filename.png")

cropped_image = image.crop((left, upper, right, lower))

比如要裁剪第一个字符:

from PIL import Image

image = Image.open("captcha.png").convert("L")

cropped_image = image.crop((0, 0, 30, 45))

cropped_image.save("cropped_image.png")

得到的图像为:

我将他打包到一个循环中,编写了一个简单的脚本,从该站点获取500个验证码图像,并将所有裁剪后的字符保存到一个文件夹中。回顾我们上一部分观察到的特征第三点,每个字符都有明确定义。

图像去杂,清理干扰因子

为了"清理"图像中的裁剪掉干扰因素(删除不必要的线和点),我们使用一个很简单的算法:

字符中的所有像素都是纯黑色(0)。如果它不是完全黑色的,将它当成白色的。因此,对于值大于0的每个像素,将给其重新赋值为255。使用load()函数将图像转换为45x180数字矩阵,然后对其进行处理。

pixel_matrix = cropped_image.load()

for col in range(0, cropped_image.height):

for row in range(0, cropped_image.width):

if pixel_matrix[row, col] != 0:

pixel_matrix[row, col] = 255

image.save("thresholded_image.png")

为了清晰起见,我将代码应用于原始图像。

原版的:

做过算法矫正的图

你可以看得到,并非完全黑暗的所有像素都被删除了。比如通过图像的线。上述方法在图像处理中的专业术语叫做阈值处理,当然还有很多处理方法,阈值处理事最简单实用的方法。

去除图像中的黑点

回顾观察到特征的第四点,图像中有许多散杂黑点像素的干扰因子。

循环遍历图像矩阵,并且如果相邻像素是白色的,并且与相邻像素相对的像素也是白色的,并且中心像素是黑色的,则设定中心像素为白色。

for column in range(1, image.height - 1):

for row in range(1, image.width - 1):

if pixel_matrix[row, column] == 0 and pixel_matrix[row, column - 1] == 255 and pixel_matrix[row, column + 1] == 255 :

pixel_matrix[row, column] = 255

if pixel_matrix[row, column] == 0 and pixel_matrix[row - 1, column] == 255 and pixel_matrix[row + 1, column] == 255:

pixel_matrix[row, column] = 255

结果为:

你可以看到,经过以上步骤的处理,图像已经只剩下字符框架了。虽然有些字符已经丢失了一些基础像素,但是每个字符的图像骨架基本上都完备。当然这个是必须的,我们做这么多处理的主要原因是为每个可能的字符都截取生成合适字符图。

构建字符图库

我将上述算法裁剪得到的所有字符图像都存储于文件夹下。下一个任务是为属于"A-Z0-9"的每个字符找到至少一个样本图像。这一步就像"训练"步骤,我手动为每个字符选择了一个字符图像并对其更名。

完成这一步后,每个字符都有一幅骨架图像!

选择最优的字符图

我还运行了其他几个脚本,确保每一个字符的图像中都有最佳的图像,例如,如果有20个'A'的字符图像,暗色(1)数量最少的图像显然是噪声最少的图像,因此最适合作为骨架图像。选择的原则:

一个按照字符排序的相似图像(约束条件:黑像素数量大小,并且相似度> = 90~95%)。

一个从每个分组字符获得最佳图像。

因此,到目前为止,我们生成了一个像素图像库。我们将它们转换为像素矩阵,并将"位图,把字符图转为数字点阵SON文件

识别算法

最后,这就是获取任何新的验证码图像的算法:

使用相同的算法尽量减少新图像中不必要的干扰因子

对于新验证码图片中的每字符,强制通过生成的JSON文件举证来匹配,基于相应的黑像素匹配来计算相似度。

如果一个像素是黑的并且在图像中的位置恰好是破解验证码,并且像素在我们的字符库中的骨架图像/位图中的相同位置处也是的,则计数会递增1。

与骨架图像中黑暗像素的数量做对比,计算匹配百分比,选择具有最高匹配百分比的字符就是识别结果的字符。

结果演示

最终结果如下:

得到的字符为Z5M3MQ, 验证码被成功识别出来了。

相关推荐

为什么fps大神都是400dpi(fps为什么高)

400DPI,在游戏里调节不同英雄的鼠标灵敏度,可以保证最小范围微调改动鼠标移动速度。因为DPI和灵敏度是乘积关系。举个例子:如果你玩麦克雷时鼠标DPI是3200,游戏内灵敏度是1。但你切换到源氏和闪...

系统集成项目管理工程师难考吗

  系统集成项目管理工程师考试的普遍通过率是在10%左右,但是并不表示考试真的有那么难。因为考试本身没有报考条件的限制,且考试报名费用很低,很多人都不重视考试。所以通过率普遍偏低,只要你认真备考,有一...

360影视大全下载2025免费版(下载360影视大全最新版下载安装到手机版)

你好朋友360影视大全里的很多视频都是免费的,建议安装最新的360影视大全就可以了打开360视频,搜索自己需要的视频,点击360播放器右下角的下载箭头,即可将视频进行下载,下载完毕之后视频会保存在36...

360安全卫士手机版下载(360安全卫士官方免费下载手机版5.5.0)

相当靠谱360手机卫士是一款由奇虎网推出的功能强、效果好、受用户欢迎的上网安全软件。360安全卫士拥有查杀木马、清理插件、修复漏洞、电脑体检、保护隐私等多种功能,并独创了“木马防火墙”“360密盘”等...

deepin和统信uos(统信和deepin的区别)

差不多。1Deepin原名LinuxDeepin、deepinos、深度操作系统,于2014年4月改名Deepin。deepin团队基于Qt/C++(用于前端)和Go(用于后端)开发了的全新深度桌...

三星驱动(三星驱动板)

驱动是必须装的,但不需要单独安装驱动。  1、电脑的所有硬件,必然要装驱动,键盘、鼠标什么的,都是有驱动的。驱动是软件和硬件结合的桥梁。但多数普通常见的硬件,驱动是widnows系统自带的,不需要用户...

u盘启动杀毒软件(u盘杀毒系统)

  有,但是主要是专杀工具,全面的综合杀毒软件基本上没有,因为没什么用。  1、放在U盘里的杀毒软件,就是不安装,也不监控,只杀毒的软件。  2、目前的杀毒软件的工作机制,主要是监控,监控电脑不感染病...

联想维修站点查询官网(联想 维修 服务网点)

您可以在联想的官方网站上查询到附近的授权维修服务点,或者拨打联想的客服电话寻求帮助。在维修服务点,您可以享受到专业的维修服务,包括硬件故障、软件问题、系统优化等方面的维护和维修。维修人员将会根据您的电...

怎么登录hotmail邮箱(邮箱登陆hotmail)
  • 怎么登录hotmail邮箱(邮箱登陆hotmail)
  • 怎么登录hotmail邮箱(邮箱登陆hotmail)
  • 怎么登录hotmail邮箱(邮箱登陆hotmail)
  • 怎么登录hotmail邮箱(邮箱登陆hotmail)
电脑不识别移动硬盘(移动硬盘灯亮但不读取)

电脑不能识别移动硬盘可能是由于以下原因造成的:1.电脑和硬盘之间的连接首先,可以确保移动硬盘正确连接到电脑上,检查USB接口是否松动或损坏,可以尝试更换USB线或者尝试连接到其他USB接口看是否能够...

键盘的win键在哪里(电脑键盘的win键在哪里)

win键就是电脑键盘上显示WINDOWS标志的按键。位于CTRL键与ALT键两个键之间,win键的具体位置一般电脑键盘上有左右两个。Windows键是一种特殊的键,通常位于键盘的左下角。它的图案是一个...

新手学做ppt(新手学做ppt的软件有哪些)
  • 新手学做ppt(新手学做ppt的软件有哪些)
  • 新手学做ppt(新手学做ppt的软件有哪些)
  • 新手学做ppt(新手学做ppt的软件有哪些)
  • 新手学做ppt(新手学做ppt的软件有哪些)
ghost全盘备份步骤图(用ghost怎么进行全盘备份)

可以用手动备份到指定分区。一、用一键Ghost还原中的“中文向导”备份开始-程序-一键Ghost-选出“中文向导”,Ghost中文向导-1、备份文件默认是“第1硬盘第1分区”,如果不是,将鼠标指针移...

键盘的windows键是哪一个(键盘上windows键是哪个键)
键盘的windows键是哪一个(键盘上windows键是哪个键)

windows键就是电脑键盘上ctrl键和alt键之间的按键,位于左下角。它带着微软的徽标,跟开始菜单一样的图标,它属于辅助按键,主要与其它按键组合使用,实现一些特定的功能,组合成多种快捷操作方式。这里上面所知的Win键其实就是键盘上的Wi...

2025-12-31 10:51 off999

win10打开设置快捷键(win10打开设置快捷键是什么)

1、首先打开电脑,在任务栏的语言地方点击一下再点击语言首选项。2、然后在新的界面里点击选择左侧“高级设置”按钮。3、之后在新的界面里点击选择“更改语言栏热键”按钮。4、然后在新的界面里点击选择“更改热...

取消回复欢迎 发表评论: