- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章python中超简单的字符分割算法记录(车牌识别、仪表识别等)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
在诸如车牌识别,数字仪表识别等问题中,最关键的就是将单个的字符分割开来再分别进行识别,如下图。最近刚好用到,就自己写了一个简单地算法进行字符分割,来记录一下.
彩图二值化以减小参数量,再进行腐蚀膨胀去除噪点.
image = cv2.imread("F://demo.jpg", 0) # 读取为灰度图_, image = cv2.threshold(image, 50, 255, cv2.THRESH_BINARY) # 二值化kernel1 = cv2.getStructuringElement(cv2.MORPH_RECT, (7, 7)) # 腐蚀膨胀核kernel2 = cv2.getStructuringElement(cv2.MORPH_RECT, (5, 5)) # 腐蚀膨胀核image = cv2.erode(image, kernel=kernel1) # 腐蚀image = cv2.dilate(image, kernel=kernel2) # 膨胀
考虑最理想的情况,图中的字符是端正没有倾斜歪曲的。将像素灰度矩阵分别进行列相加、行相加,则在得到的列和、行和数组中第一个非 0 元素索引到最后一个非 0 元素索引包裹的区间即就是字符区域.
h, w = image.shape # 原图的高和宽list1 = [] # 列和list2 = [] # 行和for i in range(w): list1.append(1 if image[:, i].sum() != 0 else 0) # 列求和,不为0置1for i in range(h): list2.append(1 if image[i, :].sum() != 0 else 0) # 行求和,不为0置1# 裁剪字符区域# 求行的范围flag = 0for i, e in enumerate(list1): if e != 0: if flag == 0: # 第一个不为0的位置记录 start_w = i flag = 1 else: # 最后一个不为0的位置 end_w = i# 求列的范围flag = 0for i, e in enumerate(list2): if e != 0: if flag == 0: # 第一个不为0的位置记录 start_h = i flag = 1 else: # 最后一个不为0的位置 end_h = iprint(start_w, end_w) # 行索引范围print(start_h, end_h) # 列索引范围
与分割全部字符区域同理,在行和数组中非 0 元素索引的范围即是单个字符的区域.
l = ([i for i, e in enumerate(list1) if e != 0]) # 列和列表中不为0的索引img_list = [] # 分割数字图片存储列表temp = [] # 存储某一个数字的所有行索引值n = 0 # 数字图片数量for x in l: temp.append(x) if x+1 not in l: # 索引不连续的情况 if len(temp) != 1: start_w = min(temp) # 索引最小值 end_w = max(temp) # 索引最大值 img_list.append(image[start_h:end_h, start_w:end_w]) # 对该索引包括数字切片 n += 1 temp = []print(n) # 字符数
import cv2start_h, end_h, start_w, end_w = 0, 0, 0, 0 # 字符区域的高和宽起止image = cv2.imread("F://001_1.jpg", 0) # 直接读取为灰度图cv2.imshow("img_GRAY", image)_, image = cv2.threshold(image, 50, 255, cv2.THRESH_BINARY) # 二值化cv2.imshow("img_BINARY", image)# 去噪点kernel1 = cv2.getStructuringElement(cv2.MORPH_RECT, (7, 7)) # 简单腐蚀膨胀核kernel2 = cv2.getStructuringElement(cv2.MORPH_RECT, (5, 5)) # 简单腐蚀膨胀核image = cv2.erode(image, kernel=kernel1) # 腐蚀image = cv2.dilate(image, kernel=kernel2) # 膨胀cv2.imshow("img_denoise", image)h, w = image.shape # 原图的高和宽# print(h, w)list1 = [] # 列和list2 = [] # 行和for i in range(w): list1.append(1 if image[:, i].sum() != 0 else 0) # 列求和,不为0置1for i in range(h): list2.append(1 if image[i, :].sum() != 0 else 0) # 行求和,不为0置1# print(len(list1))# print(len(list2))# 裁剪字符区域# 求行的范围flag = 0for i, e in enumerate(list1): if e != 0: if flag == 0: # 第一个不为0的位置记录 start_w = i flag = 1 else: # 最后一个不为0的位置 end_w = i# 求列的范围flag = 0for i, e in enumerate(list2): if e != 0: if flag == 0: # 第一个不为0的位置记录 start_h = i flag = 1 else: # 最后一个不为0的位置 end_h = iprint(start_w, end_w) # 行索引范围print(start_h, end_h) # 列索引范围cv2.imshow("img_number", image[start_h:end_h, start_w:end_w])l = ([i for i, e in enumerate(list1) if e != 0]) # 列和列表中不为0的索引# print(l)img_list = [] # 分割数字图片存储列表temp = [] # 存储某一个数字的所有行索引值n = 0 # 数字图片数量for x in l: temp.append(x) if x+1 not in l: # 索引不连续的情况 if len(temp) != 1: start_w = min(temp) # 索引最小值 end_w = max(temp) # 索引最大值 img_list.append(image[start_h:end_h, start_w:end_w]) # 对该索引包括数字切片 n += 1 # print(temp) temp = []print(n) # 字符数for i in range(n): # 显示保存字符 cv2.imshow("number"+str(i), img_list[i]) cv2.imwrite("F://demo"+str(i+1).zfill(2)+".jpg", img_list[i])cv2.waitKey(0)
利用列向和行向相加的方法简单分割字符的方法并不适用更加复杂的分割要求,另外算法中也没有考虑小数点分割问题,仅作为学习参考,欢迎有问题一起讨论交流.
到此这篇关于python中超简单的字符分割算法记录(车牌识别、仪表识别等)的文章就介绍到这了,更多相关python字符分割算法内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://blog.csdn.net/Wenyuanbo/article/details/120432356 。
最后此篇关于python中超简单的字符分割算法记录(车牌识别、仪表识别等)的文章就讲到这里了,如果你想了解更多关于python中超简单的字符分割算法记录(车牌识别、仪表识别等)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我是 ASM(字节码操作工具包)的新手,正在使用它来检测 Java 字节码。我想访问类的方法并使用 ASM 更改它们的访问修饰符。有人知道如何实现这一目标吗?我知道调用 visitMethod 会有所
如何使用 Instrumentation 从 TestCase 中控制 Android Activity 的生命周期? 关于 official documentation ,声明为“生命周期控制:使用
我正在尝试构建类似于以下内容的 SVG: 笔画是完全动态的,因为它们来自 API。我想将笔画放在收到的点上(作为百分比值数组)。不必有序且两笔之间的距离不必相等 我正在尝试类似下面的方法,但无法提出笔
我正在使用基于 (Chartjs-tsgauge) 的仪表图表。 我想为图表设置与仪表限制分开的背景颜色。如何的问题图表.JS 渲染背景,因为我使用的插件没有关于背景的代码。 例如,我有一个有限制的仪
我有一个来自 logstash 的数据,它显示了数据库中的表使用了多少空间以及表的最大分配容量。我想在 Kibana 中为每个表创建显示当前占用多少空间的仪表。 问题是最大可用空间有时会发生变化,因此
我正在使用 HighChart 的 Angular Gauge,想知道是否可以有不等的间隔。目前,Y 轴上的不等间隔会影响仪表中每个绘图带的大小。如何才能在 Y 轴上具有相等的绘图带大小和不等间隔。
我是 HighCharts 的新手。 我有一个问题,当页面上有多个仪表时,第一个仪表会消失。 这个例子工作正常: HighChart test
我正在尝试使用一些现成的 javascript 来制作仪表。我快到了,但我不知道如何管理值(value)标题。 现在我的代码是这样工作的: 这就是我喜欢它的工作方式: 不知道如何解决问题。使用 Mat
我需要创建一个如下图所示的仪表。 我尝试使用JustGage为了做到这一点,但我找不到渲染仪表下部的方法(图像中的红色半圆)。 我想使用 JustGage。有人知道如何使用 JustGage 绘制“镜
我正在尝试在页面上插入多个 Google 仪表(或 Highchart 仪表)实例。 我想使用不同的选项集并将它们分开。所以我不能使用这里介绍的解决方案,我认为:Google Charts multi
我正在创建一个单页仪表板,它将在我想显示一些图表的监视器上全屏运行。我已经制作了图表,现在我只需要一个合适的页面模板。我在想这样的事情 我真的很喜欢它的外观,但我对如何使用大概的 css/js 制作这
我正在尝试编写一个应用程序,它从加速度计中获取值并通过条形仪表(或者可能是针规)显示它们,但我不确定如何让仪表工作。我正在考虑这些选择: 将仪表分成多个部分,因此仪表“填满”的多个图像,并根据加速度计
我正在尝试使用 Modbus 协议(protocol)对 Socomec 仪表执行 ping 操作,经过研究,我发现了 NModbus,这是一个 C# 库。我之前从未使用过库或 C#(通常是 Java
是否可以将 flexdashboard(下图)中的仪表嵌入 Shiny 应用程序(shinydashboard 或 shiny) >)? 来自 flexdashboard 的 Shiny flexda
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我尝试向我的网站添加仪表,我将 js 和 css 添加到我的信息文件 比在页面中我有这段代码 $(document).ready(function(){ s1 = [1]; plo
我正在尝试在数据标签中添加图标,我成功地添加了一些像这样的 HTML return 'Partially rejected: ' + partial + '' +'Rejected: ' + reje
我发现了一些像 VU 表一样移动指针的 CSS。这模仿了我想做的事情。然而,它从头到尾做一个完整的动画。而我想通过一系列的点击来实现改变。我试图弄清楚如何做到这一点,但我没有成功。我想知道如何让针只通
我在 D3 或 C3js 中寻找这样的东西: C3 中的默认 Gauge Chart 将多个列作为数据,但随后将它们显示在同一行上,因此它们相互覆盖。 最佳答案 如果您使用的是 Angular 4,则
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我是一名优秀的程序员,十分优秀!