python验证码识别的实例详解

作者:daisy 时间:2021-05-28 14:59:51 

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

依赖


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,验证码,识别,ocr
0
投稿

猜你喜欢

  • python 函数内部修改外部变量的方法

    2022-05-24 09:04:19
  • pycharm创建并使用虚拟环境的详细图文教程

    2022-05-27 18:19:51
  • Pytorch如何切换 cpu和gpu的使用详解

    2023-08-22 03:30:11
  • java前端javascript生成动态表格示例演示

    2023-08-24 11:13:45
  • 浅谈python为什么不需要三目运算符和switch

    2022-04-02 16:22:39
  • Python 实现循环最快方式(for、while 等速度对比)

    2023-12-18 18:33:34
  • Python如何在windows环境安装pip及rarfile

    2021-01-12 18:00:21
  • css把超出的部分显示为省略号的方法兼容火狐

    2010-10-07 09:02:44
  • python实现双向链表原理

    2023-08-11 11:42:11
  • 一个数组随机不重复问题

    2008-09-02 20:05:00
  • Python Pandas常用函数方法总结

    2022-11-19 05:18:31
  • Python2.x中文乱码问题解决方法

    2023-09-20 14:35:35
  • 详解phpMyAdmin的安装和配置

    2007-06-15 09:56:00
  • Python中bisect的用法

    2023-11-05 08:47:53
  • Python如何处理异常报错方法(建议收藏!)

    2022-08-09 03:19:13
  • Python catplot函数自定义颜色的方法

    2021-01-29 16:25:01
  • 解释FCKeditor样式的工作原理

    2007-10-11 13:34:00
  • Python实现一个简单的递归下降分析器

    2022-10-05 16:23:13
  • JavaScript 设计模式 富有表现力的Javascript(一)

    2023-08-25 07:42:15
  • 如何基于Python爬虫爬取美团酒店信息

    2023-10-11 00:12:45
  • asp之家 网络编程 m.aspxhome.com