大家在平时上网浏览某些网站时可能需要登录才能看,而一般登录界面除了账号密码之外还会有一个验证码需要去进行匹配验证。如果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%免费】。