首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Python:使用OpenCV进行文本识别的字母修复

Python:使用OpenCV进行文本识别的字母修复
EN

Stack Overflow用户
提问于 2018-06-16 02:48:29
回答 1查看 1K关注 0票数 1

我正在尝试修复包含字母的图像,每个字母从中间分成两半。

原始图像

在应用以下代码后:

代码语言:javascript
复制
gray = cv2.cvtColor(cropped_bot, cv2.COLOR_BGR2GRAY)

new_img = ((gray >= 230)*255).astype('uint8')    

bottom_image =  255-new_img

我得到了这张图片

我的问题是修复将字母分成两部分的行。

我已经试过adaptiveThreshold

代码语言:javascript
复制
cv2.adaptiveThreshold(gray, 255, cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY, 15, 2)

但这并不管用。我该如何解决这个问题

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-06-16 17:45:12

以下是您可以遵循的几个步骤:

  • 在灰度图像上执行Otsu阈值
  • 使用内核

应用形态学关闭操作

代码:

代码语言:javascript
复制
ret, thresh1 = cv2.threshold(gray, 0, 255, cv2.THRESH_BINARY | cv2.THRESH_OTSU)
cv2.imshow('thresh1', thresh1)

代码语言:javascript
复制
k = np.array([[1, 1, 1], [1, 1, 1], [1, 1, 1]], np.uint8)
closing = cv2.morphologyEx(thresh1, cv2.MORPH_CLOSE, k)
cv2.imshow(closing, closing)

更新:

代码语言:javascript
复制
k1 = np.ones((3, 3), np.uint8)
erosion = cv2.erode(closing, k1, iterations = 1)
cv2.imshow(erosion, erosion)

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50881207

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档