python-openCV实现银行卡卡号识别

实现效果:

1
2

code

import cv2 as cv
import numpy as np# 轮廓排序 默认从左到右
# --cnts 待排序的轮廓列表
# --method 排序方法 自上而下,从左到右等
def sort_contours(cnts, method="left-to-right"):# 初始化反向标志和排序索引reverse = Falsei = 0# 处理是否需要逆向排序if method == "right-to-left" or method == "bottom-to-top":reverse = True# 处理时根据边界框的x坐标排序还是y坐标排序,如果是自上而下或者自下而上则需要根据y坐标排序而不是x坐标if method == "top-to-bottom" or method == "bottom-to-top":i = 1# 构建边界框list 并使用python魔术lambda表达式进行排序boundingBoxes = [cv.boundingRect(c) for c in cnts](cnts, boundingBoxes) = zip(*sorted(zip(cnts, boundingBoxes),key=lambda b: b[1][i], reverse=reverse))# 返回排序后的轮廓和边界框return (cnts, boundingBoxes)# 显示图像
def cv_show(name, img):cv.imshow(name, img)# cv.waitKey(0)# cv.destroyAllWindows()# =================================1.读入模板图像================================def loadTemplate():img = cv.imread('template.png')cv_show('src', img)# 灰度图ref = cv.cvtColor(img, cv.COLOR_BGR2GRAY)cv_show('gray', ref)# 二值化ref = cv.threshold(ref, 10, 255, cv.THRESH_BINARY_INV)[1]cv_show('binary', ref)# 计算轮廓  外轮廓refCnts, hierarchy = cv.findContours(ref.copy(), cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)print(np.array(refCnts).shape)# print('---contours', contours)# -1画所有的轮廓cv.drawContours(img, refCnts, -1, (0, 255, 0), 3)cv_show('canny', img)digits = {}# 对轮廓进行排序refCnts = sort_contours(refCnts)[0]## 模板值的对应for (i, c) in enumerate(refCnts):(x, y, w, h) = cv.boundingRect(c)# print(i, ":", (x, y, w, h))roi = ref[y:y + h, x:x + w]roi = cv.resize(roi, (57, 88))# cv_show('roi',roi)digits[i] = roireturn digits# ==========================2.读入输入图像进行处理===============================
def dealProcess(digits):# 初始化卷积核rectKernel = cv.getStructuringElement(cv.MORPH_RECT, (9, 3))sqKernel = cv.getStructuringElement(cv.MORPH_RECT, (5, 5))src = cv.imread('card.png')cv_show('src', src)inGray = cv.cvtColor(src, cv.COLOR_BGR2GRAY)cv_show('inGray', inGray)# 礼帽操作tophat = cv.morphologyEx(inGray, cv.MORPH_TOPHAT, rectKernel)cv_show('tophat', tophat)# ksize=-1 3X3gradX = cv.Sobel(tophat, ddepth=cv.CV_32F, dx=1, dy=0, ksize=-1)gradX = np.absolute(gradX)(minVal, maxVal) = (np.min(gradX), np.max(gradX))gradX = (255 * ((gradX - minVal) / maxVal - minVal))gradX = gradX.astype("uint8")cv_show('gradX', gradX)# 闭操作gradX = cv.morphologyEx(gradX, cv.MORPH_CLOSE, rectKernel)cv_show('MORPH_CLOSE', gradX)# 自动寻找合适的阈值thresh = cv.threshold(gradX, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)[1]cv_show('thresh', thresh)thresh = cv.morphologyEx(thresh, cv.MORPH_CROSS, sqKernel)cv_show('thresh-close', thresh)# 计算轮廓srcCnts, srcHierarchy = cv.findContours(thresh.copy(), cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)print(type(srcCnts))src2 = src.copy()cv.drawContours(src2, srcCnts, -1, (0, 255, 0), 3)cv_show('src', src2)locs = []for (i, c) in enumerate(srcCnts):(x, y, w, h) = cv.boundingRect(c)ar = w / float(h)# print(i, ":","rect->",(x, y, w, h), ar)if 2.8 < ar < 4.0:if (50 < w < 65) and (15 < h < 33):locs.append((x, y, w, h))locs = sorted(locs, key=lambda x: x[0])print('-------------------------')print(locs)output = []for (i, (gX, gY, gW, gH)) in enumerate(locs):groupOutput = []# 截取图像group = inGray[gY - 5:gY + gH + 5, gX - 5:gX + gW + 5]# cv_show('group', group)# 预处理  二值化group = cv.threshold(group, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)[1]cv_show('group', group)# 计算一组轮廓digitCnts, hierarchy = cv.findContours(group.copy(), cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)digitCnts = sort_contours(digitCnts)[0]# 计算每一组中每一个数值for c in digitCnts:# 找到当前数值轮廓,resize 到合适的大小(x, y, w, h) = cv.boundingRect(c)roi = group[y:y + h, x:x + w]roi = cv.resize(roi, (57, 88))# 计算匹配得分scores = []# 在模板中计算每一个的得分for (digit, digitROI) in digits.items():# 模板匹配result = cv.matchTemplate(roi, digitROI, cv.TM_CCOEFF)# 相关系数(minVal, maxVal, minLoc, maxLoc) = cv.minMaxLoc(result)scores.append(maxVal)# print(maxVal)# 得到合适的数字groupOutput.append(str(np.argmax(scores)))cv.rectangle(src, (gX - -5, gY - 5), (gX + gW + 5, gY + gH + 5), (0, 0, 255), 1)cv.putText(src, "".join(groupOutput), (gX, gY - 15), cv.FONT_HERSHEY_SIMPLEX, 0.65, (0, 0, 255), 2)# 得到结果output.extend(groupOutput)return (src, output)if __name__ == '__main__':digits = loadTemplate()(src, output) = dealProcess(digits)# 打印输出结果print("res:{}".format("".join(output)))cv_show('res', src)cv.waitKey()

用到的资源图片:

111111

感谢支持,欢迎讨论交流,谢谢!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/61411.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

opencv之银行卡号识别

1.项目背景 1.1 项目介绍 这个一个opencv的经典应用,所以用它来熟悉之前的一些操作。 1.2 项目目的 通过此程序可以识别出银行卡图片中包括的银行卡卡号。 2.项目介绍 此项目主要分为两部分:模板图片处理,银行卡图片处理。 模板图片: 银行卡图片示例: 2.1 模板图片处…

【OpenCV】银行卡号识别

文章目录 前言一、环境二、代码总结 前言 本文引用其他作者代码&#xff0c;本文仅供记录用。详细内容可看此处 一、环境 如果提示没有imutils模块就pip install imutils 提供一个字体模板文件和银行卡图片。可以右键保存。 字体模板文件&#xff1a; 银行卡图片&#xff1b…

opencv-python 银行卡卡号识别

模板&#xff1a; 银行卡&#xff1a; 主要思路&#xff1a;用遮盖法 将无关紧要的上面和下面部分截掉&#xff0c;保留银行卡号差不多的位置&#xff0c;然后用opencv做图像处理&#xff0c;得到四个 连着数字的小框框&#xff0c;然后再在四个小框框里面提取出每一个单个的…

使用 OpenCV 和 Python 识别信用卡号

使用 OpenCV 和 Python 识别信用卡号 在之前的博文中&#xff0c;我们学习了如何安装 Tesseract 二进制文件并将其用于 OCR。 然后我们学习了如何使用基本的图像处理技术来清理图像以提高 Tesseract OCR 的输出。 但是&#xff0c;不应将 Tesseract 视为能够获得高精度的光学…

OpenCV-Python 模板匹配的银行卡号识别

目录 实现流程模板数字处理对模板图片进行二值化处理对二值化后的图片进行轮廓检测确定每个模板数字的图像 银行卡图片处理预处理确定每组数字轮廓检测每个数字提取数字组中的数字 模板匹配附录完整代码 实现流程 对数字模板进行处理&#xff0c;提取出单一数字的图片&#xf…

银行卡验证接口API(仅需一行代码,实现全国银行卡核验)

银行卡确认在互联网越来越普及&#xff0c;在二手、电商、贷款、等主流互联网应用中都有明确的刚需&#xff0c;传统的 银行卡核验方式是用户上传图片&#xff0c;客服后台人肉审核&#xff0c;但问题在于根本无从确认 银行卡的真实性&#xff0c;也不能确认该 银行卡持有人和身…

openCV+Python实战练习——银行卡号识别

目录 项目Introduce&#xff1a; 项目名称&#xff1a; 具体操作步骤以及代码&#xff1a; 实现结果展示&#xff1a; 代码整体展示&#xff1a; 项目Introduce&#xff1a; 项目名称&#xff1a; 通过导入模板数字&#xff0c;对银行卡面上的数字进行识别&#xff0c;提…

【opencv学习】银行卡的识别

今天做一个小项目&#xff0c;运用已经学到的知识&#xff0c;做一个银行卡的识别。 银行卡的图像如下 这个银行卡是的数字模板是 现在我的任务是识别中间的16个数字 大致思路是&#xff1a; 1&#xff1a;读取模板&#xff0c;获得每个数字的模板信息 2&#xff1a;读取银行…

OpenCV C++案例实战二十《银行卡号识别》

OpenCV C案例实战二十《银行卡号识别》 前言一、获取模板图像1.1 功能效果1.2 功能源码 二、银行卡号定位2.1 将银行卡号切割成四块2.1.1 功能效果2.1.2 功能源码 2.2 字符切割2.2.1 功能效果2.2.2 功能源码 三、字符识别3.1.读取文件3.2.字符匹配3.3.功能源码 四、效果显示4.1…

opencv实际案例(一)银行卡号的识别

一、目标&#xff1a; 识别银行卡上的卡号 二、思路&#xff1a; 一 、准备模板&#xff0c;能够与卡号数字样式进行模型匹配 二、处理模板图片&#xff1a;将其分割成为单个数字的图片&#xff0c;和所对应的数字相匹配存储可迭代的数据类型中。 读入模板图片&#xff0…

(openCV--python)检测银行卡号 (应用篇)(包含模板图)

适合人群&#xff1a; 有python基础&#xff0c;注重应用、不追求深层次知识的小伙伴。前言&#xff1a; 本文对很多说用到的很多函数都是粗浅地解释一下用法以及作用&#xff0c;并不会解释该函数的具体结构。若想进一步深入了解还请自行谷狗一下。 完整代码 # Author :Eri…

opencv项目实践二(银行卡卡号识别)

任务说明 将银行卡卡号打印输出 实现 一、思路 1、定位银行卡卡号数字区域 2、将银行卡每个卡号数字单独提取出来 3、处理模板图片&#xff0c;将每个模板数字单独提取出来 4、通过模板匹配来识别每个卡号 二、具体代码实现 1、处理模板 卡号数字模板 # 读取模板图片 img_…

CVAT——2. CVAT简单使用

文章目录 基本使用管理员界面登录管理用户添加/删除用户及用户权限管理组管理 任务管理 创建任务和上传标签datumaroanaconda安装datumaro安装datumaro基本使用支持的格式查看帮助文件报错导入projects数据增加 数据标注标注面板使用快捷键左侧工具栏和右侧面板说明追踪模式Tra…

OpenCV图像处理——(实战)信用卡识别

总目录 图像处理总目录←点击这里 十四、信用卡数字识别 识别的图片模板图片 14.1、模板图片处理 读入图片->灰度图->二值图->计算轮廓->存储每一个模板 如果是所需模板匹配只有一个&#xff0c;课直接读入灰度图像即可 这里有10个模板(0-9)&#xff0c;所以需…

关于opencv的实战——银行卡号识别

首先我们先来引入我们所需要的库和我们定义的图像显示&#xff08;方便&#xff09;&#xff1a; import cv2 import numpy as np import imutils from imutils import contours#显示图像 def cv_show(img,name"image"):cv2.imshow(name,img)cv2.waitKey(0)cv2.dest…

13- 信用卡账号识别 (OpenCV基础) (项目十三) *

项目要点 _, ref cv2.threshold(ref, 10, 255, cv2.THRESH_BINARY_INV) 二值化处理图片, 黑白化图片ref cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) 灰度化处理ref_contours, _ cv2.findContours(ref.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) 计算轮廓cv2.dr…

OpenCv图像处理实战——银行卡卡号识别

图像处理项目 测试图片自取区 card1 card2 银行卡卡号识别 from imutils import contours import numpy as np import argparse import imutils import cv2 import myutils #argparse这个库可以让我们直接在命令行中就可以向程序中传入参数并让程序运行。#这两个方法在包中没…

【OpenCV】 ⚠️实战⚠️ 银行卡卡号读取 ☢️建议手收藏☢️

【OpenCV】 ⚠️实战⚠️ 银行卡卡号读取 概述预处理代码模板预处理银行卡预处理 计算轮廓代码模板轮廓银行卡轮廓 其他程序主函数代码数字分割最终结果 概述 今天带大家使用我们之前学会的知识来实现银行卡卡号读取. 代码分为四个部分: 主函程序, 预处理, 计算轮廓, 其他程序…

openCV实践项目:银行卡卡号识别

本文用于对之前openCV知识点学习的复习及实践。要求达到以下效果&#xff1a; 一、基本流程思路分析 本项目本质上就是进行模板匹配。 注&#xff1a;为多用到所学知识&#xff0c;为了加深理解多加了些步骤&#xff0c;实际上本项目可以很简单就能完成。 1.1 模板处理 模…

什么是物联网平台

1、什么是物联网平台 阿里云物联网平台为设备提供安全可靠的连接通信能力&#xff0c;向下连接海量设备&#xff0c;支撑设备数据采集上云&#xff1b;向上提供云端API&#xff0c;服务端通过调用云端API将指令下发至设备端&#xff0c;实现远程控制。 物联网平台消息通信流程…