python验证码识别的实例详解


Posted in Python onSeptember 09, 2016

其实关于验证码识别涉及很多方面的内容,入手难度大,但是入手后,可拓展性又非常广泛,可玩性极强,成就感也很足,对这感兴趣的朋友们下面跟着小编一起来学习学习吧。

依赖

sudo apt-get install python-imaging
sudo apt-get install tesseract-ocr
pip install pytesseract

利用google ocr来识别验证码

from PIL import Image
import pytesseract
image = Image.open('v1.jpg')
vcode = pytesseract.image_to_string(image)
print vcode

但是pytesseract本身识别率不高,而且一般网站的验证码都带有大量干扰元素。( ̄? ̄)"

所以我们首先要对验证码进行去噪。

对于单像素干扰线、干扰点我们可以通过扫描整个图像,考察每一个像素点所临近的八个像素点的颜色,如果不同的个数大于一定的值,那就说明该点是离散点,需要去除。

另外也可以尝试设定阈值来直接将验证码二值化。

下面是两张学校网站上的验证码

python验证码识别的实例详解

python验证码识别的实例详解

我们可以看到验证码存在单像素干扰点,所以我们需要设法去除。但是经过反复刷新验证码,发现这个验证码

     1. 只有加法运算

     2.至多两位数的加法

     3.文字部分一定是红色(255,0,0)

有了上述的信息,可以判断这个验证码的生成算法是有缺陷的

import Image 
from numpy import * 
import pytesseract 
im = Image.open('1.png') 
im = im.convert('RGB') 
#拉长图像,方便识别。
im = im.resize((200,80)) 
a = array(im) 
for i in xrange(len(a)): 
for j in xrange(len(a[i])): 
  if a[i][j][0] == 255: 
    a[i][j]=[0,0,0] 
  else: 
    a[i][j]=[255,255,255] 
im = Image.fromarray(a) 
im.show() 
vcode = pytesseract.image_to_string(im) 
print vcode

利用上述脚本我们可以将图像进行二值化,利用google ocr进行识别。再通过eval()来对表达式进行求值。

总结

python验证码识别的内容到这就基本介绍了,希望这篇文章对大家的学习或者工作能有所帮助,如果有疑问大家可以留言交流。

Python 相关文章推荐
python模拟鼠标拖动操作的方法
Mar 11 Python
python MySQLdb Windows下安装教程及问题解决方法
May 09 Python
Python实现的最近最少使用算法
Jul 10 Python
对python3 urllib包与http包的使用详解
May 10 Python
python实现NB-IoT模块远程控制
Jun 20 Python
Python 保持登录状态进行接口测试的方法示例
Aug 06 Python
python3 反射的四种基本方法解析
Aug 26 Python
Python操作列表常用方法实例小结【创建、遍历、统计、切片等】
Oct 25 Python
Python time库基本使用方法分析
Dec 13 Python
Python 字典一个键对应多个值的方法
Sep 29 Python
什么是Python装饰器?如何定义和使用?
Apr 11 Python
如何基于python实现单目三维重建详解
Jun 25 Python
Python随机数random模块使用指南
Sep 09 #Python
利用ctypes提高Python的执行速度
Sep 09 #Python
python实现批量监控网站
Sep 09 #Python
利用python批量检查网站的可用性
Sep 09 #Python
Python如何判断数独是否合法
Sep 08 #Python
python框架django基础指南
Sep 08 #Python
python中星号变量的几种特殊用法
Sep 07 #Python
You might like
phpmyadmin的#1251问题
2006/11/25 PHP
php闭包中使用use声明变量的作用域实例分析
2018/08/09 PHP
php实现获取近几日、月时间示例
2019/07/06 PHP
你真的了解JavaScript吗?
2007/02/24 Javascript
js取两个数组的交集|差集|并集|补集|去重示例代码
2013/08/07 Javascript
用jquery写的一个万年历(自写)
2014/01/20 Javascript
jquery根据属性和index来查找属性值并操作
2014/07/25 Javascript
jQuery插件Skippr实现焦点图幻灯片特效
2015/04/12 Javascript
jQuery下拉美化搜索表单效果代码分享
2015/08/25 Javascript
跟我学习javascript的undefined与null
2015/11/17 Javascript
jquery实现具有收缩功能的垂直导航菜单
2016/02/16 Javascript
JavaScript必知必会(二) null 和undefined
2016/06/08 Javascript
JSONP和批量操作功能的实现方法
2016/08/21 Javascript
利用Node.JS实现邮件发送功能
2016/10/21 Javascript
Ajax实现不刷新取最新商品
2017/03/01 Javascript
jQuery.Form实现Ajax上传文件同时设置headers的方法
2017/06/26 jQuery
利用types增强vscode中js代码提示功能详解
2017/07/07 Javascript
微信小程序wx.uploadfile 本地文件转base64的实现代码
2018/06/28 Javascript
VUE兄弟组件传值操作实例分析
2019/10/26 Javascript
了不起的11个JavaScript代码重构最佳实践小结
2021/01/11 Javascript
Python Unittest根据不同测试环境跳过用例的方法
2018/12/16 Python
实例详解Python模块decimal
2019/06/26 Python
python区块及区块链的开发详解
2019/07/03 Python
使用python将多个excel文件合并到同一个文件的方法
2019/07/09 Python
基于Python实现剪切板实时监控方法解析
2019/09/11 Python
selenium与xpath之获取指定位置的元素的实现
2021/01/26 Python
基于css3的属性transition制作菜单导航效果
2015/09/01 HTML / CSS
CSS3圆角和渐变2种常用功能详解
2016/01/06 HTML / CSS
医学护理系毕业生求职信
2013/10/01 职场文书
海飞丝广告词
2014/03/20 职场文书
庆祝三八妇女节标语
2014/10/09 职场文书
2014年家长学校工作总结
2014/11/20 职场文书
高三英语教学计划
2015/01/23 职场文书
收银员岗位职责范本
2015/04/07 职场文书
农村结婚典礼主持词
2015/06/29 职场文书
vue数据字典取键值项目的字典问题
2022/04/12 Vue.js