在上一篇博客Python图像处理之图片文字识别(OCR)中我们介绍了在Python中如何利用Tesseract软件来识别图片中的英文与中文,本文将具体介绍如何在Python中利用Tesseract软件来识别验证码(数字加字母)。

我们在网上浏览网页或注册账号时,会经常遇到验证码(CAPTCHA),如下图:

本文将具体介绍如何利用Python的图像处理模块pillow和OCR模块pytesseract来识别上述验证码(数字加字母)。

我们识别上述验证码的算法过程如下:

将原图像进行灰度处理,转化为灰度图像;

获取图片中像素点数量最多的像素(此为图片背景),将该像素作为阈值进行二值化处理,将灰度图像转化为黑白图像(用来提高识别的准确率);

去掉黑白图像中的噪声,噪声定义为:以该点为中心的九宫格的黑点的数量小于等于4;

利用pytesseract模块识别,去掉识别结果中的特殊字符,获得识别结果。

我们的图片如下(共66张图片):

完整的Python代码如下:

import os

import pytesseract

from PIL import Image

from collections import defaultdict

# tesseract.exe所在的文件路径

pytesseract.pytesseract.tesseract_cmd = 'C://Program Files (x86)/Tesseract-OCR/tesseract.exe'

# 获取图片中像素点数量最多的像素

def get_threshold(image):

pixel_dict = defaultdict(int)

# 像素及该像素出现次数的字典

rows, cols = image.size

for i in range(rows):

for j in range(cols):

pixel = image.getpixel((i, j))

pixel_dict[pixel] += 1

count_max = max(pixel_dict.values()) # 获取像素出现出多的次数

pixel_dict_reverse = {v:k for k,v in pixel_dict.items()}

threshold = pixel_dict_reverse[count_max] # 获取出现次数最多的像素点

return threshold

# 按照阈值进行二值化处理

# threshold: 像素阈值

def get_bin_table(threshold):

# 获取灰度转二值的映射table

table = []

for i in range(256):

rate = 0.1 # 在threshold的适当范围内进行处理

if threshold*(1-rate)<= i <= threshold*(1+rate):

table.append(1)

else:

table.append(0)

return table

# 去掉二值化处理后的图片中的噪声点

def cut_noise(image):

rows, cols = image.size # 图片的宽度和高度

change_pos = [] # 记录噪声点位置

# 遍历图片中的每个点,除掉边缘

for i in range(1, rows-1):

for j in range(1, cols-1):

# pixel_set用来记录该店附近的黑色像素的数量

pixel_set = []

# 取该点的邻域为以该点为中心的九宫格

for m in range(i-1, i+2):

for n in range(j-1, j+2):

if image.getpixel((m, n)) != 1: # 1为白色,0位黑色

pixel_set.append(image.getpixel((m, n)))

# 如果该位置的九宫内的黑色数量小于等于4,则判断为噪声

if len(pixel_set) <= 4:

change_pos.append((i,j))

# 对相应位置进行像素修改,将噪声处的像素置为1(白色)

for pos in change_pos:

image.putpixel(pos, 1)

return image # 返回修改后的图片

# 识别图片中的数字加字母

# 传入参数为图片路径,返回结果为:识别结果

def OCR_lmj(img_path):

image = Image.open(img_path) # 打开图片文件

imgry = image.convert('L') # 转化为灰度图

# 获取图片中的出现次数最多的像素,即为该图片的背景

max_pixel = get_threshold(imgry)

# 将图片进行二值化处理

table = get_bin_table(threshold=max_pixel)

out = imgry.point(table, '1')

# 去掉图片中的噪声(孤立点)

out = cut_noise(out)

#保存图片

# out.save('E://figures/img_gray.jpg')

# 仅识别图片中的数字

#text = pytesseract.image_to_string(out, config='digits')

# 识别图片中的数字和字母

text = pytesseract.image_to_string(out)

# 去掉识别结果中的特殊字符

exclude_char_list = ' .:\\|\'\"?![],()~@#$%^&*_+-={};<>/¥'

text = ''.join([x for x in text if x not in exclude_char_list])

#print(text)

return text

def main():

# 识别指定文件目录下的图片

# 图片存放目录figures

dir = 'E://figures'

correct_count = 0 # 图片总数

total_count = 0 # 识别正确的图片数量

# 遍历figures下的png,jpg文件

for file in os.listdir(dir):

if file.endswith('.png') or file.endswith('.jpg'):

# print(file)

image_path = '%s/%s'%(dir,file) # 图片路径

answer = file.split('.')[0] # 图片名称,即图片中的正确文字

recognizition = OCR_lmj(image_path) # 图片识别的文字结果

print((answer, recognizition))

if recognizition == answer: # 如果识别结果正确,则total_count加1

correct_count += 1

total_count += 1

print('Total count: %d, correct: %d.'%(total_count, correct_count))

'''

# 单张图片识别

image_path = 'E://figures/code (1).jpg'

OCR_lmj(image_path)

'''

main()

运行结果如下:

('101659', '101659')

('111073', '111073')

('114510', '114510')

('118235', '118235')

('124677', '124677')

('147291', '147291')

('169147', '169147')

('185302', '185302')

('23YB', '23YB')

('262051', '262051')

('2HED', '2MED')

('315386', '315386')

('3D7K', '3D7K')

('3DYH', '3DYH')

('3QG8', '30G8')

('3XNR', 'EXNR')

('44G5', '44G5')

('470259', '470259')

('515413', '515413')

('522351', '522351')

('539824', '539824')

('5CVL', 'SCVL')

('642689', '642689')

('671991', '671991')

('672838', '672838')

('6F5Y', '6F5Y')

('6USB', 'GUSB')

('703167', '703167')

('765120', '765120')

('779931', '779931')

('8UEF', '8SUEF')

('905857', '905857')

('9H4H', '9H4H')

('9SK1', 'OSK1')

('BDP4', 'BDP4')

('DXV3', 'DXV3')

('E78Y', 'E78Y')

('EAHR', 'EAHR')

('F585', 'Fss§')

('FBV8', 'FBV8')

('FJKK', 'FJKK')

('GXKQ', 'GXKQ')

('H7Y9', 'H7Y9')

('J4LJ', 'J4LJ')

('J8YH', 'J8YH')

('JCDL', 'JCDL')

('JTX2', 'JTX2')

('JYLH', 'JYLH')

('KFYA', 'KFYA')

('L3VZ', 'L3VZ')

('LCGV', 'LCGV')

('LKEK', 'LKEK')

('N3FJ', 'N3FJ')

('PJZN', 'PJZN')

('PNDQ', 'PNDQ')

('Q7HP', 'Q7HP')

('QSHU', 'QSHU')

('R1RN', 'RLRN')

('RPNX', 'RPNX')

('TUKG', 'TUKG')

('U9G3', 'U9G3')

('UZAH', 'UZAH')

('V6P9', 'very')

('Y18D', '18D')

('Y237', 'Y237')

('ZZT5', '2215')

Total count: 66, correct: 54.

我们可以看到图片识别的正确率为80%以上,其中数字类图片的识别正确率为100%.

我们可以在图片识别方面的算法再加改进,以提高图片识别的正确率。当然,以上算法并不是对所有验证码都适用,不同的验证码需要用不同的图片处理算法。

注意:本人现已开通两个微信公众号: 因为Python(微信号为:python_math)以及轻松学会Python爬虫(微信号为:easy_web_scrape), 欢迎大家关注哦~~

python识别图片中数字_Python图像处理之图片验证码识别相关推荐

  1. python批量识别图片中文字_python实现中文图片文字识别--OCR about chinese text--tesseract...

    0.我的环境: win7 32bits python 3.5 pycharm 5.0 1.相关库 安装pillow: pip install pillow 安装tesseract: 自带了英文语言包, ...

  2. python图像识别系统_Python图像处理之图片文字识别功能(OCR)

    OCR与Tesseract介绍 将图片翻译成文字一般被称为光学文字识别(Optical Character Recognition,OCR).可以实现OCR 的底层库并不多,目前很多库都是使用共同的几 ...

  3. python文字识别时、当文字不清晰时怎么处理_Python图像处理之图片文字识别功能(OCR)...

    OCR与Tesseract介绍 将图片翻译成文字一般被称为光学文字识别(Optical Character Recognition,OCR).可以实现OCR 的底层库并不多,目前很多库都是使用共同的几 ...

  4. python文字识别算法_Python图像处理之图片文字识别(OCR)

    OCR与Tesseract介绍 将图片翻译成文字一般被称为光学文字识别(Optical Character Recognition,OCR).可以实现OCR 的底层库并不多,目前很多库都是使用共同的几 ...

  5. python识别图片中数字_Python实现识别图片上的数字

    Python 3.6版本的Pytesseract图像验证代码识别 环境: (1)win7 64位(2)想法(3)python 3.6(4)pip安装枕头 pip install pytesseract ...

  6. python识别图片中数字_Python Opencv识别两张相似图片

    在网上看到python做图像识别的相关文章后,真心感觉python的功能实在太强大,因此将这些文章总结一下,建立一下自己的知识体系. 当然了,图像识别这个话题作为计算机科学的一个分支,不可能就在本文简 ...

  7. 字符识别Python实现 图片验证码识别

    字符型图片验证码识别完整过程及Python实现 1   摘要 验证码是目前互联网上非常常见也是非常重要的一个事物,充当着很多系统的 防火墙 功能,但是随时OCR技术的发展,验证码暴露出来的安全问题也越 ...

  8. 字符型图片验证码识别完整过程及Python实现

    1   摘要 验证码是目前互联网上非常常见也是非常重要的一个事物,充当着很多系统的 防火墙 功能,但是随时OCR技术的发展,验证码暴露出来的安全问题也越来越严峻.本文介绍了一套字符验证码识别的完整流程 ...

  9. 微博模拟登陆的方法 + 图灵图像图片验证码识别平台 识别验证码(97%正确率)Python + Selenium+Chrome

    最近遇到一个问题,需要频繁切换账号登陆微博,但是需要识别微博的验证码,比较麻烦.而且因为需要24h不间断的操作,所以没法使用人工打码平台,而且打码平台也比较贵,延迟又高.最后找到了一个可以机器识别出来 ...

最新文章

  1. 彩色条形码轻松解决盲人购物难题!无需对焦,识别速度快12倍,还能发出过敏警告...
  2. 内存分配的几个函数的简单对比分析
  3. 支持任意排序的分页存储过程
  4. 强大的Qtstylesheet
  5. 搜索引擎提交软件_网站如何被搜索引擎快速收录?
  6. CART分类树算法的最优特征选择
  7. visual svn server安装失败
  8. java前端框架有哪些_web前端框架有哪些
  9. 概念讲解:大地水准面 | 地球椭球体 | 参考椭球体 | 大地基准面 | 地图投影
  10. 无刷马达驱动方案之电动工具方案设计
  11. 程序员 -- 当我彻底放弃自私自利后,前途变得一片光明,不能过多的只是关注自己的功夫,生活不能只局限在方寸虚拟世界里
  12. 适合学生党和上班族的祛痘方法
  13. 地图名片:百度地图 高德地图 pc 移动端快速实现地图生成、标记以及标注获取链接及代码(霸霸看了都说好)
  14. 【数据机构】最短路径之Dijkstra算法(迪克斯特拉算法)
  15. 简单理解 TP、FN、FT 及 TN和准确率、精确率、召回率 的含义
  16. 用python判断是否为闰年
  17. 24c0x读写 大于256字节读写方式,以24c08为例(24c04/08/16同理)
  18. 传奇3服务器数据修改,传奇3游戏架设技术之3.0服务器架设和设置攻略详细分享...
  19. python大众点评网实训报告中的参考文献_python小练习(052):爬取大众点评网美食版块+数据库储存+大数据分析(二)...
  20. MongoDB配置副本集

热门文章

  1. java简洁日历代码
  2. 【实战篇】37 # 如何使用 QCharts 图表库绘制常用数据图表?
  3. 计算机发展史之查尔斯·巴贝奇
  4. 如何在Lyx中添加参考文献,以及生成参考文献目录
  5. 一个简单的SQL注入攻击
  6. uint_t(uint8_t)和size_t
  7. 2.4 随机变量函数的分布
  8. android root 模拟点击,免ROOT实现模拟点击任意位置
  9. iphone手机safari浏览器访问网站滚动条不显示问题解决办法
  10. ubuntu下远程访问服务器的方法