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金融数据可视化汇总
Nov 17 Python
读取本地json文件,解析json(实例讲解)
Dec 06 Python
详解tensorflow实现迁移学习实例
Feb 10 Python
Python2中文处理纪要的实现方法
Mar 10 Python
Python 2.7中文显示与处理方法
Jul 16 Python
Python3.5文件修改操作实例分析
May 01 Python
python 通过可变参数计算n个数的乘积方法
Jun 13 Python
python3.4+pycharm 环境安装及使用方法
Jun 13 Python
Python模拟FTP文件服务器的操作方法
Feb 18 Python
python应用Axes3D绘图(批量梯度下降算法)
Mar 25 Python
Python Selenium库的基本使用教程
Jan 04 Python
asyncio异步编程之Task对象详解
Mar 13 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
Smarty模板快速入门
2007/01/04 PHP
zf框架的Filter过滤器使用示例
2014/03/13 PHP
PHP实现的购物车类实例
2015/06/17 PHP
Zend Framework动作助手Json用法实例分析
2016/03/05 PHP
Yii2实现同时搜索多个字段的方法
2016/08/10 PHP
关于PHP转换超过2038年日期出错的问题解决
2017/06/28 PHP
ThinkPHP实现转换数据库查询结果数据到对应类型的方法
2017/11/16 PHP
YII框架关联查询操作示例
2019/04/29 PHP
跨浏览器的 mouseenter mouseleave 以及 compareDocumentPosition的使用说明
2010/05/04 Javascript
js中unicode转码方法详解
2015/10/09 Javascript
jquery实现删除一个元素后面的所有元素功能
2015/12/21 Javascript
基于JavaScript实现网页倒计时自动跳转代码
2015/12/28 Javascript
Angular工具方法学习
2016/12/26 Javascript
JS闭包用法实例分析
2017/03/27 Javascript
详解webpack4.x之搭建前端开发环境
2019/03/28 Javascript
微信小程序的注册页面包含倒计时验证码、获取用户信息
2019/05/22 Javascript
使用vue-cli3+typescript的项目模板创建工程的教程
2020/02/28 Javascript
VSCode launch.json配置详细教程
2020/06/18 Javascript
详解Howler.js Web音频播放终极解决方案
2020/08/23 Javascript
WebPack工具运行原理及入门教程
2020/12/02 Javascript
vue图片裁剪插件vue-cropper使用方法详解
2020/12/16 Vue.js
Python写的一个简单DNS服务器实例
2014/06/04 Python
Python面向对象编程中的类和对象学习教程
2015/03/30 Python
Python restful框架接口开发实现
2020/04/13 Python
scrapy redis配置文件setting参数详解
2020/11/18 Python
canvas像素画板的实现代码
2018/11/21 HTML / CSS
H5混合开发app如何升级的方法
2018/01/10 HTML / CSS
大学生旅游业创业计划书
2014/01/29 职场文书
房屋产权证明书
2014/10/15 职场文书
年度考核个人总结
2015/03/06 职场文书
八一建军节主持词
2015/07/01 职场文书
小学体育跳绳课教学反思
2016/02/16 职场文书
小学语文的各类谚语(70首)
2019/08/15 职场文书
在Java中Collection的一些常用方法总结
2021/06/13 Java/Android
Python基础之变量的相关知识总结
2021/06/23 Python
Python 详解通过Scrapy框架实现爬取CSDN全站热榜标题热词流程
2021/11/11 Python