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访问sqlserver示例
Feb 10 Python
使用python实现递归版汉诺塔示例(汉诺塔递归算法)
Apr 08 Python
解决windows下Sublime Text 2 运行 PyQt 不显示的方法分享
Jun 18 Python
解析Python中的生成器及其与迭代器的差异
Jun 20 Python
Python使用正则表达式抓取网页图片的方法示例
Apr 21 Python
利用Python找出序列中出现最多的元素示例代码
Dec 08 Python
详解利用python+opencv识别图片中的圆形(霍夫变换)
Jul 01 Python
使用python绘制cdf的多种实现方法
Feb 25 Python
python实时监控logstash日志代码
Apr 27 Python
基于python实现查询ip地址来源
Jun 02 Python
python集合能干吗
Jul 19 Python
PyTorch 导数应用的使用教程
Aug 31 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
一段实用的php验证码函数
2016/05/19 PHP
php实现图片以base64显示的方法
2016/10/13 PHP
一个JQuery写的点击上下滚动的小例子
2011/08/27 Javascript
JS加jquery简单实现标签元素的显示或隐藏
2013/09/23 Javascript
Javascript Web Slider 焦点图示例源码
2013/10/10 Javascript
js操作输入框提示信息且响应鼠标事件
2014/03/25 Javascript
node-webkit打包成exe文件被360误报木马的解决方法
2015/03/11 Javascript
jQuery插件Tooltipster实现漂亮的工具提示
2015/04/12 Javascript
jquery插件validation实现验证身份证号等
2015/06/04 Javascript
关于使用axios的一些心得技巧分享
2017/07/02 Javascript
vue 数组和对象不能直接赋值情况和解决方法(推荐)
2017/10/25 Javascript
jquery无缝图片轮播组件封装
2020/11/25 jQuery
Vue跨域请求问题解决方案过程解析
2020/08/07 Javascript
Openlayers学习之地图比例尺控件
2020/09/28 Javascript
[02:49]2014DOTA2电竞也是体育项目! 势要把荣誉带回中国!
2014/07/20 DOTA
python统计cpu利用率的方法
2015/06/02 Python
Python win32com 操作Exce的l简单方法(必看)
2017/05/25 Python
Python:Scrapy框架中Item Pipeline组件使用详解
2017/12/27 Python
用python简单实现mysql数据同步到ElasticSearch的教程
2018/05/30 Python
python+opencv 读取文件夹下的所有图像并批量保存ROI的方法
2019/01/10 Python
TensorFlow基于MNIST数据集实现车牌识别(初步演示版)
2019/08/05 Python
pytorch查看torch.Tensor和model是否在CUDA上的实例
2020/01/03 Python
python实现批量命名照片
2020/06/18 Python
详解win10下pytorch-gpu安装以及CUDA详细安装过程
2021/01/28 Python
英国户外装备和冒险服装零售商:alloutdoor
2018/01/30 全球购物
市场部经理岗位职责
2014/04/10 职场文书
《雕塑之美》教学反思
2014/04/24 职场文书
不忘国耻振兴中华演讲稿
2014/05/14 职场文书
大型演出策划方案
2014/05/28 职场文书
班级读书活动总结
2014/06/30 职场文书
目标责任书格式
2014/07/28 职场文书
公民授权委托书范本
2014/09/17 职场文书
合作协议书模板
2014/10/10 职场文书
批评与自我批评发言稿
2014/10/15 职场文书
幼儿园教师暑期培训心得体会
2016/01/09 职场文书
python字典的元素访问实例详解
2021/07/21 Python