Python怎么识别验证码?Python如何通过验证码校验

大家在平时上网浏览某些网站时可能需要登录才能看,而一般登录界面除了账号密码之外还会有一个验证码需要去进行匹配验证。如果python爬虫抓取数据时无法通过验证码校验的话就没办法进入到实际有数据的页面了,所以本篇文章会来讲解一下python识别验证码的方法。

Python怎么识别验证码?Python如何通过验证码校验

这次要来给讲解的这个方法只适用于图片验证码,像滑块和拼图、以及图像物体识别类型的验证码就不能够用这种方法,这些类型的验证码需要模拟鼠标操作浏览器才可以实现。

而使用python识别图片验证码,实际上是将验证码图片下载下来之后将其转换成八位像素的模式,这样就能够得到这个验证码上面每一个像素点的值了。在值比较突出的位置就是验证码文字所在的颜色,代码示例如下所示:

from PIL import Image
im = Image.open("captcha.gif")
im.convert("P")
his im.histogram()

转换完成之后会得到一个直方图的数组,在这个数组之中每一个数字实际上表示的就是索引位置处的像素数量,数量越多也就是表示它是文字的可能性越大。然后就是循环迭代这个数组并将其排序之后取出来一定范围内的数值,代码如下所示:

values = {}
for i in range(256):
  values[i] = his[i]
for j,k in sorted(values.items(),key=lambda x:x[1],reverse = True)[:10]:
  print j, k

这些数值就是图片验证码之中数量最多的颜色,那么现在就是需要根据图片上的颜色来实际的获取到验证码文字值了,详细代码示例如下所示:

im2 = Image.new("P",im.size,255)
for x in range(im.size[1]):
    for y in range(im.size[0]):
        pix = im.getpixel((y,x))
        if pix == 220 or pix == 227: # these are the numbers to get
            im2.putpixel((y,x),0)
im2.show()

以上就是关于“Python怎么识别验证码?Python如何通过验证码校验”的全部内容了,希望对你有所帮助。

关于Python技术储备

学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

一、Python所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

在这里插入图片描述

二、Python必备开发工具

三、Python视频合集

观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

四、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

五、Python练习题

检查学习结果。

六、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 最后祝大家天天进步!!

上面这份完整版的Python全套学习资料已经上传至CSDN官方,朋友如果需要可以直接微信扫描下方CSDN官方认证二维码免费领取【保证100%免费】。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值