如何使用python-opencv批量生成带噪点噪线的数字验证码

第一次使用csdn写一个文章,如果有什么写的不对的地方,欢迎在下面评论指正,谢谢各位。

1.明确要使用的包

首先就是opencv的函数库,还有python自带的random和PIL(Image、ImageDraw、ImageFont),一般pthon3以上的版本都是内置安装的,如果没有安装可以通过pip install的方法安装具体操作如图:

输入完按回车键即可安装,因为我已经安装了,就不输入回车键了,安装完了之后可以通过import的方式检验是否安装成功。记住先输入python进入python的编程环境在输入import PIL,否则就会报错

2.引入库

代码如下(示例):

import cv2 as cv
import random
from PIL import Image
from PIL import ImageDraw
from PIL import ImageFont

3.生成随机的颜色组合get_random_color()

彩色图像是由RGB三色通道构成的,但是要注意在opencv里面的彩色图像是按照BGR的顺序来构成彩色图像的,与其他的地方采用图像的顺序不一样(例如halcon就是安装RGB的顺序来引用彩色图像),
采用函数的形式来形成一个三个数组,当函数返回的数值超过三个的时候,就会以数组的形式返回。
代码如下(示例):

# 随机生成不同颜色的组合
def get_random_color():
  B = random.randint(0, 255)
  G = random.randint(0, 255)
  R = random.randint(0, 255)
  # 防止生成白色噪声噪线
  # 使用三个if条件判断防止三个通道的颜色都是255(虽然是不可能事件)
  if B == 255:
    B = 0
  elif G == 255:
    G = 0
  elif R == 255:
    R = 0
  return(B, G, R)

如果你不放心是否返回了一个数组,可以进行验证

#用于测试是否获得了数组
a = get_random_color()
print(a)

4.生成颜色随机,数值随机的数字生成函数get_random_number()

这个函数比较简单,原理也是和上面随机生成颜色组合一样。
代码如下(示例):

# 随机生成数字
def get_random_number():
  random_num = str(random.randint(0, 9))
  return random_num

5.随机生成一张干净的(不带噪声噪线)数字验证码图像

使用PIL的Image、ImageDraw、ImageFont分别用于生成白色图像背景、定义画笔用于往图像写入数字、定义文字的字形和字体大小。
代码如下(示例):

def generate_image():
  # 生成白色图像,'RGB'类型,宽高为(150,50),底色为白色(255,255,255)
  image = Image.new('RGB', (150, 50), (255,255,255))
  # 定义画笔,将图像与画笔关联
  draw = ImageDraw.Draw(image)
  # 定义文字字形以及字体大小
  font = ImageFont.truetype("arial.ttf", size=36)

  name = "" # 定义一个空的字符串,用于不断叠加数字,给图像命名
  for i in range(5):
    random_number = get_random_number()
    # 不断叠加随机生成的数字,用于给图像命名
    name += random_number

    # 在图片上写上数字,参数是:定位、数字(字符串)、颜色、字型
    draw.text((10+i*30, 0), random_number, get_random_color(), font=font)
  # 将图像保存到指定的文件夹,下面使用xxxx的形式代表文件夹
  image.save('G:\xxxxxx\xxxxxxxx\%s.png' % name)

字体可以根据自己电脑已有的字体来选择,具体路径是C:\Windows\Fonts,

 font = ImageFont.truetype("arial.ttf", size=36)

6.往图像添加噪声噪线

函数的这一步不使用新的函数,继续接着上一个函数( generate_image())输入代码,为什么不使用?因为在读取图像的时候我们会用到name这个函数,如果使用新的函数的话,就无法使用这个变量。当然也可以通过类的方法,实现两个函数之间的变量可以相互调用,这个就稍微麻烦点,这里就不过多讲述了。
代码如下(示例):
(再次提醒下面代码是接着generate_image()的,所以下面代码都有一个缩进)

width = 150
  height = 50
  # 读取文件夹的图像,通过name来读取指定的图像,
  img = cv.imread('G:\xxxxxx\xxxxxxxxxxxx\%s.png' %name)
  # 绘制噪点
  for i in range(5):
    x = random.randint(0, width)
    y = random.randint(0, height)
    # 绘制实心圆,必须输入参数分别是:图像、圆心的位置、半径、颜色,
    #最后一个是thickness默认是None,绘制空心圆,指定为-1绘制实心圆
    cv.circle(img, (x,y), 1, get_random_color(), -1)

  # 绘制噪线
  for i in range(3):
    x1 = random.randint(0, width)
    y1 = random.randint(0, height)
    x2 = random.randint(0, width)
    y2 = random.randint(0, height)
    # 绘制线条,参数分别是:图像、左上角的坐标、右下角的坐标、颜色
    cv.line(img, (x1,y1), (x2,y2), get_random_color())
  # 保存图像
  cv.imwrite(r'G:\xxxxx\xxxxxxx\%s.png'%name, img)

7.调用函数生成数字验证码图像

所有的函数都已经写完,直接调用图像生成函数就行了。
使用for循环,循环调用generate_image()即可实现批量生成图像,想要多少张就循环多少次。

for i in range(30):
  generate_image()

8.总结

到这一步所有的工作已经完成了,可以去保存的指定文件夹看一下,是否成功生成,一般程序没有报错基本都是可以生成的。

第一次使用csdn写文章,肯定会有很多纰漏和不足,有什么建议和意见都可以在下面评论提出,我会一一更正,谢谢各位

到此这篇关于如何使用python-opencv批量生成带噪点噪线的数字验证码的文章就介绍到这了,更多相关opencv批量生成噪点验证码内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • OpenCV搞定腾讯滑块验证码的实现代码

    前言 废话 滑块验证码破解是一直都想搞的项目,毕竟多数网站都会采用滑块验证码,于是最近在修改论文的闲暇之余把这事儿给解决了.要搞现在的滑块验证码绕不开图像处理,图像处理当然是首推OpenCV-Python啦!当然我的OpenCV非常菜(P.S.两天速成不敢保证代码质量),发现问题就直接指出嘛,不用走流程啦! 环境 首先需要一个python,然后安装opencv的python库,如下: pip install opencv-python 然后测试一下是否可用,如下: import cv2 as c

  • python opencv pytesseract 验证码识别的实现

    一.环境配置 需要 pillow 和 pytesseract 这两个库,pip install 安装就好了. install pillow -i http://pypi.douban.com/simple --trusted-host pypi.douban.com pip install pytesseract -i http://pypi.douban.com/simple --trusted-host pypi.douban.com 安装好Tesseract-OCR.exe pytesse

  • 使用Python的OpenCV模块识别滑动验证码的缺口(推荐)

    最近终于找到一个好的方法,使用Python的OpenCV模块识别滑动验证码的缺口,可以将滑动验证码中的缺口识别出来了. 测试使用如下两张图片: target.jpg template.png 现在想要通过"template.png"在"target.jpg"中找到对应的缺口,代码实现如下: # encoding=utf8 import cv2 import numpy as np def show(name): cv2.imshow('Show', name) cv

  • 基于opencv的selenium滑动验证码的实现

    基于selenium进行动作链 由于最近很多人聊到滑动验证码怎么处理,所以决定自己动手试一下. 做一个东西前.我们首先要对这个东西的操作过程有一个大概的了解. 打开验证码页面. 鼠标放到拖动按钮上 对拖动按钮进行拖动 拖动到阴影快重合的位置. 放开拖动按钮. from selenium import webdriver from selenium.webdriver.common.action_chains import ActionChains artice = browser.find_el

  • 如何使用python-opencv批量生成带噪点噪线的数字验证码

    第一次使用csdn写一个文章,如果有什么写的不对的地方,欢迎在下面评论指正,谢谢各位. 1.明确要使用的包 首先就是opencv的函数库,还有python自带的random和PIL(Image.ImageDraw.ImageFont),一般pthon3以上的版本都是内置安装的,如果没有安装可以通过pip install的方法安装具体操作如图: 输入完按回车键即可安装,因为我已经安装了,就不输入回车键了,安装完了之后可以通过import的方式检验是否安装成功.记住先输入python进入python

  • python基于opencv批量生成验证码的示例

    基本思路是使用opencv来把随机生成的字符,和随机生成的线段,放到一个随机生成的图像中去. 虽然没有加复杂的形态学处理,但是目前看起来效果还不错 尝试生成1000张图片,但是最后只有998张,因为有有重复的,被覆盖掉了. 代码如下: import cv2 import numpy as np line_num = 10 pic_num = 1000 path = "./imgs/" def randcolor(): return (np.random.randint(0,255),n

  • 三分钟教会你用Python+OpenCV批量裁剪xml格式标注的图片

    目录 前言 xml文件格式 代码思想 完整代码 效果展示 总结 前言 在目标检测中,数据集常常使用labelimg标注,会生成xml文件.本文旨在根据xml标注文件来裁剪目标,以达到去除背景信息的目的. xml文件格式 以下是一个标注好的图片生成的xml文件.具体含义见代码注释. <annotation> <!--xml所属文件夹--> <folder>JPEGImages</folder> <!--对应图片所属文件夹--> <filena

  • Python3批量生成带logo的二维码方法

    最近有个需求:批量生成带Logo的二维码 生成二维码比较简单,网上的资源也比较多,不赘述了.自己研究了一下加了logo并且美化了一下(网上的资源直接加Logo特别丑!!!忍不了!!!),直接上代码: def create_qrcode(url, filename): qr = qrcode.QRCode( version=1, #设置容错率为最高 error_correction=qrcode.ERROR_CORRECT_H, box_size=10, border=4, ) qr.add_da

  • Python+opencv+pyaudio实现带声音屏幕录制

    基于个人的爱好和现实的需求,决定用Python做一个屏幕录制的脚本.因为要看一些加密的视频,每次都要登录,特别麻烦,遂决定用自己写的脚本,将加密视频的播放过程全程录制下来,这样以后看自己的录播就好了.结合近期自己学习的内容,正好用Python来练练手,巩固自己的学习效果. 经过多番搜索,决定采用Python+opencv+pyaudio来实现屏幕录制.网上搜索到的录屏,基本都是不带声音的,而我要实现的是带声音的屏幕录制.下面就开始一步一步的实现吧. 声音录制 import pyaudio imp

  • 利用Python脚本批量生成SQL语句

    通过Python脚本批量生成插入数据的SQL语句 原始SQL语句: INSERT INTO system_user (id, login_name, name, password, salt, code, createtime, email, main_org, positions, status, used, url, invalid, millis, id_card, phone_no, past, end_date, start_date) VALUES ('6', 'db', 'db',

  • Python如何批量生成和调用变量

    这几天写代码中遇到的一个常见问题,在Python中如何批量的生成一些变量,如生成变量X1, X2, X3,并在后续的方法中调用,完成赋值.取值等操作.这个问题也算是常见的吧,之前遇到过,也不了了之了.而这次遇到了同样的问题,虽然是创建三个变量数量较少,但从代码维护和易读性的角度考虑,需要使用一些恰当的手段,来避免重复写三次同样代码带来的弊端.一百次,一万次?总不能复制这么多次吧.(为何不复制?详情参考软件工程中的软件维护). 因此有必要养成良好的习惯,而不是复制三次同样的代码. 使用Locals

  • 用Python实现批量生成法务函代码

    目录 情境问题 代码实现: 总结 情境问题 小王是一名法务专员,工作中会处理所在公司的侵权事件并向侵权方发送法务函. 他会按照[法务函模板.docx] Word 文件给[封号名单.xlsx]工作簿中的每个封号人员生成一份法务函. 实现这个结果,他需要手动将[封号名单.xlsx]工作簿中的封号人员的名字和微信号添加到[法务函模板.docx] Word 文件对应的位置上,并将[法务函模板.docx] Word 文件另存为新的文件. 封号人员的人数有多少,他就得重复多少次.以第一个封号人员为例,实现过

  • 如何使用Python+ChatGPT批量生成论文

    目录 用Python+ChatGPT批量生成论文概述 下载论文 pdf转文本 用GPT-3生成概述 输出概述 集成测试 总结 用Python+ChatGPT批量生成论文概述 做算法研究离不开阅读大量论文.从海量论文中找到需要的论文往往耗费算法团队不少的精力. ChatGPT官方例子中有一个“TL;DR”摘要生成,非常适合生成论文摘要. 于是我用python+GPT-3 API开发了一个工具,可以直接从arxiv地址生成论文概述.实现步骤如下: 下载论文 第一步,我们要先拿到论文正文. 从arxi

  • python opencv minAreaRect 生成最小外接矩形的方法

    使用python opencv返回点集cnt的最小外接矩形,所用函数为 cv2.minAreaRect(cnt) ,cnt是点集数组或向量(里面存放的是点的坐标),并且这个点集不定个数. 举例说明:画一个任意四边形(任意多边形都可以)的最小外接矩形,那么点集 cnt 存放的就是该四边形的4个顶点坐标(点集里面有4个点) cnt = np.array([[x1,y1],[x2,y2],[x3,y3],[x4,y4]]) # 必须是array数组的形式 rect = cv2.minAreaRect(

随机推荐