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

适合人群:

    有python基础,注重应用、不追求深层次知识的小伙伴。

前言:

  • 本文对很多说用到的很多函数都是粗浅地解释一下用法以及作用,并不会解释该函数的具体结构。若想进一步深入了解还请自行谷狗一下。

完整代码

# Author :Eric
# -*- codeing = utf-8 -*-
# @Time :2022/6/20 19:54
# @Author :ghfghd
# @Site :
# @File :main.py
# @Software :PyCharmimport cv2
import numpy as np
from imutils import contours#定义一个展示图像的函数
def cv_show(img ,name ="img"):cv2.imshow(name,img)cv2.waitKey(0)#读入模板
template  = cv2.imread('sample.png')
# cv_show(template) --A
#灰度处理
tem_gray  =cv2.cvtColor(template,cv2.COLOR_BGR2GRAY)
# cv_show(tem_gray)---B#二值化处理,thresh只接受灰度图,10为最低阈值,255为最高阈值
#最后一个参数表示,图中的像素值大于最高阈值时取0,而低于最低阈值取255
tem_thresh = cv2.threshold(tem_gray, 10,255,cv2.THRESH_BINARY_INV)[1]
# cv_show(tem_thresh)----C#轮廓检测.findContours 只接受二值图   
#RETR_EXTERNAL 只检测外轮廓   CHAIN_APPROX_SIMPLE 只保留终点坐标
tem_contours ,hierarchy = cv2.findContours(tem_thresh.copy(),cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE)
# print(type(tem_contours))
# print(np.array(tem_contours).shape)#画轮廓,从左到右参数分别表示:图像,轮廓,显示所有轮廓,用红色的笔画出轮廓,笔的粗细状况
cv2.drawContours(template,tem_contours,-1,(0,0,255),3)
# cv_show(template)---D
#给轮廓排序,将十个轮廓分别存进一个元组中
tem_sort = contours.sort_contours(tem_contours,method= "left-to-right")[0]
# print(tem_sort)digits  ={}
#获取模板中每个数字的图像
for (i,c) in enumerate(tem_sort):#获取每个轮廓在图像中的位置参数(x,y,w,h) = cv2.boundingRect(c)#根据得到的参数取出目标图像roi =tem_thresh[ y:y+h,x:x+w ]#将每个模板调成合适大小roi = cv2.resize(roi,(57,88))digits[i] =roi#-----------------------------我是分割线----------------------------------------------
#接下准备处理信用卡#先初始化卷积核,之后会用来进行闭操作,顶帽rectKernel =cv2.getStructuringElement(cv2.MORPH_RECT,(9,3))
sqKernel = cv2.getStructuringElement(cv2.MORPH_RECT,(5,5))#读入需要识别的图像
image = cv2.imread('band_card.png')
# cv_show(image)
#调整成合适大小
image = cv2.resize(image,(250,200))
# cv_show(image)
#灰度化
img_gray = cv2.cvtColor(image,cv2.COLOR_BGR2GRAY)
# cv_show(img_gray)#顶帽突出明亮处
top_img =cv2.morphologyEx(img_gray,cv2.MORPH_TOPHAT,rectKernel)
# cv_show(top_img)#sobel算子计算梯度,检测边缘
grad_X = cv2.Sobel(top_img,ddepth = cv2.CV_32F,dx= 1,dy = 0,ksize=-1)# -1表示用3*3的核
#然后操作一番,得出归一化的结果
grad_X = np.absolute(grad_X)
( minVal,maxVal )= (np.min(grad_X),np.max(grad_X))
grad_X = (255*(grad_X-minVal)/(maxVal-minVal))
grad_X = grad_X.astype("uint8")
# print(type(grad_X))
# print(np.array(grad_X).shape)#闭操作(先膨胀再腐蚀),将检测边缘后的图像中的数字连在一起,方便后期筛查无光轮廓
clo_gra =cv2.morphologyEx(grad_X ,cv2.MORPH_CLOSE,rectKernel)
# cv_show(clo_gra)#二值化
#cv2.THRESH_OTSU方法会自动寻找合适的阈值,适合处理像素分布符合双峰的图
#用此方法需要将最低阈值设定成0
thr_gra = cv2.threshold(clo_gra,0,255,cv2.THRESH_BINARY|cv2.THRESH_OTSU)[1]
# cv_show(thr_gra)#闭操作(先膨胀后腐蚀)把数字连在一起
cloag_gra = cv2.morphologyEx(thr_gra,cv2.MORPH_CLOSE,sqKernel)#计算轮廓
#findContours 只接受二值图   RETR_EXTERNAL 只检测外轮廓   CHAIN_APPROX_SIMPLE 只保留终点坐标
img_contours ,hierarchy = cv2.findContours(cloag_gra.copy(),cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE)
# print(type(img_contours))
#画轮廓
dra_img = cv2.drawContours(image.copy(),img_contours,-1,(0,0,255),1)
# cv_show(dra_img)#此处是筛选出合理的轮廓,剔除无关轮廓
#我们要找的轮廓时数字块,而图中的数字块宽和高在一个比较特别的比例之内,据此可以排除无关轮廓
locs = []
for (i,c ) in enumerate(img_contours):(x,y,w,h) = cv2.boundingRect(c)ar =w/float(h)if ar >2.5 and ar<4.0:if (w>40 and w<55) and (h >10 and h <20):locs.append((x,y,w,h))
locs  =sorted(locs , key = lambda x:x[0])
output = []#---------------------------------我是分割线-----------------------------
#以下是核心
for (i , (gx,gy,gw,gh)) in enumerate(locs): #gx,gy,gw,gh是关于轮廓的参数 并遍历数字块(注:此处说到的数字块指的是信用卡中连在一起的数字)group_output= []group  = img_gray[gy-5:gy+gh+5,gx-5:gx+gw+5]cv_show(group)#二值一下group_thr =cv2.threshold(group,0,255,cv2.THRESH_BINARY|cv2.THRESH_OTSU)[1]#计算轮廓digit_cou ,hierarchy = cv2.findContours(group_thr.copy(),cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE)#给轮廓排个序digit_cou = contours.sort_contours(digit_cou,method ="left-to-right")[0]for c in digit_cou:     #遍历数字块中的每一个数字(x,y,w,h) = cv2.boundingRect(c)#定位出每一个数字roi = group_thr[y:y+h,x:x+w]#将数字的图像调成合适大小roi =cv2.resize(roi ,(57,88))#用以记录匹配得分scores = []for (digit ,digitROI)  in digits.items():#匹配match_img = cv2.matchTemplate(roi,digitROI,cv2.TM_CCOEFF)#计算跟每个数字的匹配度(_,score,_,_) =cv2.minMaxLoc(match_img)scores.append(score)#用np.argmax方法得出最高分的数字并添进总输出中group_output.append(str(np.argmax(scores)))#每一块数字块识别完毕后,用矩形框出并显示出内容cv2.rectangle(image,(gx-5,gy-5),(gx+gw+5,gy+gh+5),(0,0,255),1)cv2.putText(image,"".join(group_output),(gx,gy-15),cv2.FONT_HERSHEY_SIMPLEX,0.65,(0,0,255),2)#将这组识别到的数字块添到一个准备好的数组中output.extend(group_output)cv_show(image)
print("".join(output))

思路:

  • 关于如何识别银行卡号,本程序的将该问题划分为三大块内容:处理匹配模板处理银行卡用模板对银行卡进行匹配

处理模板

  • 先将用来匹配的模板读入 —A
    在这里插入图片描述
  • 然后对这个模板一顿输出———灰度处理(简单去除无关背景),二值化(进一步去除无关背景,并突出轮廓)。—B(以下如图)

在这里插入图片描述
在这里插入图片描述

  • 然后我们检测一下模板中的轮廓,并将轮廓画出来保存下来外轮廓,然后把这些轮廓排个序—C
  • 在这里插入图片描述
  • 最后将模板中的每个数字的图像抓取出来,装进一个元组中

处理银行卡

  1. 首先读入银行卡顺便定义两个卷积核,一个卷积核是根据银行卡号中数字块(如:4000,1234)的长度定义为了之后利用二值化时突出数字块,并将其调整成合适大小—E
    -在这里插入图片描述
  2. 先对图像预处理。然后对这个银行卡一顿操作,由于呀银行卡的影响元素更多,故会进行更多的图像操作。灰度化,顶帽(突出明亮处),sobel算子检测边缘并将得到的梯度(此处只计算了x方向的梯度,读者可以根据实际情况判断是否有需要求y方向的梯度)进行一系列操作。

灰度后的顶帽操作
(灰度后的顶帽操作)
199595551
(sobel算子)

  1. 之后,为了能够取出数字块,进行闭操作(先膨胀再腐蚀),二值化,再进行一次二值化
    在这里插入图片描述
    (第一次闭操作)
    在这里插入图片描述
    (二值)
    在这里插入图片描述
    (第二次闭操作)

  2. 开始寻找轮廓,并将轮廓画出,然后根据实际情况(我们要找的轮廓时数字块,而图中的数字块宽和高在一个比较特别的比例之内,据此可以排除无关轮廓)排除无关轮廓
    在这里插入图片描述
    (此图还未排除无关轮廓)

匹配

(此处其实还包括一部分对银行卡的处理)
此处是最后一步。得到数字块轮廓后,可根据此抠出其中的数字块,接下来是扣出数字块中的一个个数字,在扣出一个数字时就需将其与模板中的数字匹配,识别出是什么数字。最后在数字块上根据识别出来的数字输出在其之上(数字块中抠出来的数字就不展示了)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

最后

  • 此方法只能处理最理想的情况,若是图像是歪歪斜斜的,怎么处理?大概就得用到透视变换了。笔者水平有限,若文中有纰漏,还请读者朋友不吝赐教,予以斧正。有问题欢迎私信笔者,看到后会第一时间回复。

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

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

相关文章

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;实现远程控制。 物联网平台消息通信流程…

新兴 IoT 物联网场景中 MQTT 与 TCP 通信协议对比

在IoT 物联网开发中&#xff0c;大多数通信模组都支持 TCP、UDP、MQTT、CoAP、HTTP、LwM2M 等网络通信协议&#xff0c;其中既有传输层协议&#xff0c;也有应用层的协议&#xff0c;不同协议适用的场景也不同。 我们在设计IoT硬件产品时&#xff0c;通常只需选择一种协议即可。…

lot物联网场景通用架构分享

1.通用参考架构&#xff1a; 2.lot物联网硬件设备上云技术方案&#xff1a; #lot物联网业务链路包含&#xff1a;数据采集&#xff0c;通信连接&#xff0c;数据存储&#xff0c;数据可视化&#xff0c;洞察&#xff0c;行动决策&#xff1b;其中以设备端各种厂商提供得协议差…

物联网网络通讯知识

RTU是什么 RTU英文全称Remote Terminal Units&#xff0c;中文全称为远程终端单元。远程终端设备(RTU)是安装在远程现场的电子设备&#xff0c;用来监视和测量安装在远程现场的传感器和设备。通俗理解就是能够编程的还可以将数据传输到服务器的工具。RTU内部是包含通讯模块的&…

APP与服务器之间通过 http(POST、GET)进行数据交互 ( 实现一个简单的物联网系统-1 )

文章目录 一、APP POST 数据到服务器二、APP 从服务器 GET 数据三、APP 界面部分四、相关疑问五、学习方法六、专栏地址 一、APP POST 数据到服务器 首先 post 的数据应该包括识别这个花卉的信息和我们想要浇水的量&#xff0c;这里我们识别花卉采用花卉的名字&#xff0c;这样…

什么是物联网(Internet of Things)?

你可能在某些时候会听到物联网这个词&#xff0c;但是你对它可能不知所以然&#xff0c;这篇文章让你弄清楚什么是物联网&#xff0c;以及它代表什么&#xff1f; 物联网&#xff08;Internet of Things&#xff09;是指设备到互联网的连接。汽车&#xff0c;厨房电器&#xff…

物联网网关有哪些能力和哪些应用?

工业物联网的应用受到越来越多企业的关注&#xff0c;很多人都了解网关这个概念。网关就是一个网络连接到另一个网口的桥梁&#xff0c;起到协议解析、数据采集的作用&#xff0c;实现运行状态数据的高效利用。 物联网网关具备的能力 1、广泛连接的能力 目前各个行业、不同设…

一文了解物联网网关

物联网是指通过射频识别(RFID)、红外感应器、GPS、激光扫描器等信息传感设备&#xff0c;按约定的协议&#xff0c;实现任何时间、任何地点、任何物体进行信息交换和通信&#xff0c;以实现智能化识别、定位、监控和管理的一种网络。物联网是具有全面感知、可靠传输、智能处理特…

什么是物联网?有哪些应用?终于有人讲明白了

作者&#xff1a;佩里利&#xff08;Perry Lea&#xff09; 来源&#xff1a;大数据DT&#xff08;ID&#xff1a;hzdashuju&#xff09; 我们将从连接设备的角度来研究物联网&#xff0c;这些设备之前未必相互连接或接入互联网。它们可能一直没有太多的计算或通信能力。我们假…

LPWA物联网通信

物联网LPWA是物联网中的无线通信技术之一。 根据物联网无线通信技术的覆盖距离&#xff0c;大致可分为两类&#xff1a;一类是短距离通信技术&#xff0c;包括蓝牙(蓝牙)&#xff1b;NFC,Zigbee、WIFI、NFC&#xff0c;主要用于室内智能家庭、消费电子等场景&#xff1b;另一种…

物联网通讯协议:MQTT,NB-IOT,Zigbee,CoAP,RFID,BLUETOOTH,NFC,4G,HTTP

目录 一、按网络四层协议分类二、按需要网关来分类三、NB-IoT&#xff0c;4G对比四、应用层协议&#xff1a;MQTT和COAP对比物联网组网技术WIFI蓝牙ZigBee2G/4G/5GNB-IoTLoRa网关 物联网中常见的物联通信协议TCPUDPTCP和UDP比较HTTPMQTTCoAPLwM2M 一、按网络四层协议分类 NB-I…

chatgpt赋能python:如何使用Python拷贝微信聊天记录的图片?

如何使用Python拷贝微信聊天记录的图片&#xff1f; 微信聊天记录中的图片是我们很重要的一部分。它们记录了我们和我们的朋友、家人和同事之间的重要时刻和特殊瞬间。然而&#xff0c;有些时候我们需要把这些图片从微信聊天记录中拷贝出来&#xff0c;以便于备份和共享。本文…