Python使用captcha制作验证码的实现示例
作者:Keras深度学习 时间:2023-04-16 00:49:35
在使用Keras搭建验证码识别模型时,需要大量的验证码图片。在这里,使用captcha模块生成验证码图片,验证码图片名称为验证码上显示的字符串。
1 生成单张验证码图片并显示
生成一张验证码的代码如下:
from captcha.image import ImageCaptcha
import matplotlib.pyplot as plt
import numpy as np
import random
import string
#characters为验证码上的字符集,10个数字加26个大写英文字母
#0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ str类型
characters=string.digits+string.ascii_uppercase
width,height,n_len,n_class=170,80,4,len(characters)
#设置验证码图片的宽度widht和高度height
#除此之外还可以设置字体fonts和字体大小font_sizes
generator=ImageCaptcha(width=width,height=height)
#生成随机的4个字符的字符串
random_str=''.join([random.choice(characters) for j in range(4)])
#生成验证码
img=generator.generate_image(random_str)
#显示验证码图片和验证码标题
plt.imshow(img)
plt.title(random_str)
plt.show()
程序运行结果为:
2 验证码图片的显示与保存
上面代码中生成的验证码是PIL图像格式,因此也可以直接使用PIL自带的show方法显示图片,save方法保存图片
如下:
#显示验证码
img.show()
#保存验证码
file_name=random_str+'.jpg'
img.save(file_name)
3 批量生成验证码样本集
当我们在深度学习中,进行验证码进行字符识别,需要大量的图片,因此我们可以批量生成大量的样本。这里以生成一万张样本为例。
代码如下:
from captcha.image import ImageCaptcha
import matplotlib.pyplot as plt
import numpy as np
import random
import string
from PIL import Image
#characters为验证码上的字符集,10个数字加26个大写英文字母
#0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ str类型
characters=string.digits+string.ascii_uppercase
width,height,n_len,n_class=170,80,4,len(characters)
#生成一万张验证码
for i in range(10000):
generator=ImageCaptcha(width=width,height=height)
random_str=''.join([random.choice(characters) for j in range(4)])
img=generator.generate_image(random_str)
#将图片保存在目录yzm文件夹下
file_name='./yzm/'+random_str+'_'+str(i)+'.jpg'
img.save(file_name)
当程序执行完,会在文件夹yzm下生成一万张验证码图片
来源:https://keras-lx.blog.csdn.net/article/details/89919821
标签:Python,captcha,验证码
0
投稿
猜你喜欢
Django实现WebSocket在线聊天室功能(channels库)
2023-04-01 00:41:55
Golang中实现数据脱敏处理的go-mask包分享
2024-02-12 17:24:55
Javascript typeof与instanceof的区别
2024-06-07 15:53:47
详解如何利用docker快速构建MySQL主从复制环境
2024-01-25 08:25:33
Python中GIL的使用详解
2022-02-08 13:36:30
Python词法结构
2022-01-10 00:33:21
Python 中类的构造方法 __New__的妙用
2021-04-06 04:45:56
Pycharm配置opencv与numpy的实现
2021-09-19 08:20:55
python实现银行管理系统
2021-07-09 00:33:49
Python的for和break循环结构中使用else语句的技巧
2022-07-02 16:59:26
Asp与JS的数组和字符串下标介绍
2022-10-11 13:40:25
远程访问MySQL数据库的方法小结
2024-01-13 17:58:57
MySQL隔离级别和锁机制的深入讲解
2024-01-14 06:57:53
SQL Server 2005 FOR XML嵌套查询使用详解
2009-01-06 11:20:00
python自动化之re模块详解
2021-07-01 19:34:16
asp中Access与Sql Server数据库区别总结
2007-11-18 15:08:00
Python ConfigParser模块的使用示例
2023-12-02 03:35:15
ERROR CODE: 1175 YOU ARE USING SAFE UPDATE MODE AN
2024-01-17 21:57:50
oracle学习笔记(二)
2012-01-05 18:59:20
一文带你重温一下Python的对象模型
2022-09-15 15:52:52