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实现BT种子和磁力链接的相互转换
Nov 09 Python
python进程管理工具supervisor的安装与使用教程
Sep 05 Python
Django在win10下的安装并创建工程
Nov 20 Python
Python构建网页爬虫原理分析
Dec 19 Python
python基础知识(一)变量与简单数据类型详解
Apr 17 Python
python实现QQ批量登录功能
Jun 19 Python
python变量的存储原理详解
Jul 10 Python
Python搭建代理IP池实现获取IP的方法
Oct 27 Python
基于python实现语音录入识别代码实例
Jan 17 Python
Python3使用tesserocr识别字母数字验证码的实现
Jan 29 Python
python反编译教程之2048小游戏实例
Mar 03 Python
python实现股票历史数据可视化分析案例
Jun 10 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多进程中的阻塞与非阻塞操作实例分析
2020/03/04 PHP
JavaScript 学习笔记(十四) 正则表达式
2010/01/22 Javascript
JS特殊函数(Function()构造函数、函数直接量)区别介绍
2013/05/19 Javascript
Javascript模拟加速运动与减速运动代码分享
2014/12/11 Javascript
举例详解JavaScript中Promise的使用
2015/06/24 Javascript
js实现div拖动动画运行轨迹效果代码分享
2015/08/27 Javascript
window.setInterval()方法的定义和用法及offsetLeft与style.left的区别
2015/11/11 Javascript
详解JS中Array对象扩展与String对象扩展
2016/01/07 Javascript
jQuery中队列queue()函数的实例教程
2016/05/03 Javascript
switch语句的妙用(必看篇)
2016/10/03 Javascript
javascript中的后退和刷新实现方法
2016/11/10 Javascript
jQuery插件FusionCharts绘制的2D条状图效果【附demo源码】
2017/05/13 jQuery
微信小程序methods中定义的方法互相调用的实例代码
2018/08/07 Javascript
微信小程序上传文件到阿里OSS教程
2019/05/20 Javascript
vue element自定义表单验证请求后端接口验证
2019/12/11 Javascript
js防抖函数和节流函数使用场景和实现区别示例分析
2020/04/11 Javascript
python中split方法用法分析
2015/04/17 Python
使用Python的web.py框架实现类似Django的ORM查询的教程
2015/05/02 Python
Python常用的文件及文件路径、目录操作方法汇总介绍
2015/05/21 Python
Python lxml模块安装教程
2015/06/02 Python
python学习之第三方包安装方法(两种方法)
2015/07/30 Python
python中join()方法介绍
2018/10/11 Python
python 判断参数为Nonetype类型或空的实例
2018/10/30 Python
opencv python统计及绘制直方图的方法
2019/01/21 Python
在Python中构建增广矩阵的实现方法
2019/07/01 Python
Python + Flask 实现简单的验证码系统
2019/10/01 Python
Python单元测试与测试用例简析
2019/11/09 Python
Python三维绘图之Matplotlib库的使用方法
2020/09/20 Python
浅谈HTML5 服务器推送事件(Server-sent Events)
2017/08/01 HTML / CSS
详解HTML5布局和HTML5标签
2020/10/26 HTML / CSS
2014年班干部工作总结
2014/11/25 职场文书
给老婆的检讨书(搞笑版)
2015/05/06 职场文书
为什么你写的height:100%不起作用
2021/05/10 HTML / CSS
叶县这家生产军用电台的兵工厂,人称“四机部”,走出一上将
2022/02/18 无线电
Python各协议下socket黏包问题原理
2022/04/12 Python
js前端面试常见浏览器缓存强缓存及协商缓存实例
2022/06/21 Javascript