加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

如何使用python在Image中查找字母

发布时间:2020-12-16 22:29:42 所属栏目:Python 来源:网络整理
导读:我有一个图像,其中包含一些米手写的值,我想找到字母m的位置,所以我可以裁剪它,只留下数字. 这是一个例子: 原始图像:输入图像如下所示,实际上这是我能得到的最好的手写输入,通常情况会更糟. 火车图像:我有一个m字母的列表,从我有的不同手写图像切割. 结果

我有一个图像,其中包含一些米手写的值,我想找到字母m的位置,所以我可以裁剪它,只留下数字.

这是一个例子:

原始图像:输入图像如下所示,实际上这是我能得到的最好的手写输入,通常情况会更糟.

enter image description here

火车图像:我有一个m字母的列表,从我有的不同手写图像切割.

enter image description here

结果图:我想得到的结果

enter image description here

我已经尝试过使用opencv模板匹配功能,但它不起作用,也发现这个github,但它也使用模板匹配.
我想知道是否还有其他方法可以解决这个问题.

最佳答案
似乎这封信总是在数字的末尾.如果是这样,您可以采用更简单的方法:

>找到所有轮廓;

?

>创建边界框列表(即每个轮廓一个框);

?

>确定哪一个是最右边的边界框;

?

>使用所有其他框的(x,y,宽度,高度)信息来创建ROI并仅裁剪数字;

?

Python 2.7和OpenCV 2.4的源代码:

import cv2

### load input image and convert it to grayscale
img = cv2.imread("input.png")
print("img shape=",img.shape)
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)

#### extract all contours
_,contours,_  = cv2.findContours(gray.copy(),cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)

# debug: draw all contours
#cv2.drawContours(img,-1,(0,255),2)
#cv2.imwrite("all_contours.jpg",img)

#### create one bounding box for every contour found
bb_list = []
for c in contours:  
    bb = cv2.boundingRect(c)
    # save all boxes except the one that has the exact dimensions of the image (x,width,height)
    if (bb[0] == 0 and bb[1] == 0 and bb[2] == img.shape[1] and bb[3] == img.shape[0]):
        continue
    bb_list.append(bb)

# debug: draw boxes
#img_boxes = img.copy()
#for bb in bb_list:
#   x,w,h = bb
#   cv2.rectangle(img_boxes,(x,y),(x+w,y+h),2)
#cv2.imwrite("boxes.jpg",img_boxes)    

#### sort bounding boxes by the X value: first item is the left-most box
bb_list.sort(key=lambda x:x[0])

# debug: draw the last box of the list (letter M)
#print("letter M @ ",bb_list[-1])
#x,h = bb_list[-1]
#cv2.rectangle(img,2)
#cv2.imwrite("last_contour.jpg",img)

### remove the last item from the list,i.e. remove box for letter M
bb_list = bb_list[:-1]

### and now the fun part: create one large bounding box to rule them all
x_start,_,_ = bb_list[0]
x_end,w_end,_ = bb_list[-1]

x = x_start
w = (x_end + w_end) - x_start

bb_list.sort(key=lambda y:y[1]) # sort by Y value: the first item has the smallest Y value 
_,_ = bb_list[0]

bb_list.sort(key=lambda y:y[3]) # sort by Height value: the last item has the largest Height value 
_,h = bb_list[-1]

print("x=",x,"y=","w=","h=",h)

# debug: draw the final region of interest
roi_img = img.copy()
cv2.rectangle(roi_img,2)
cv2.imwrite("roi.jpg",roi_img)

# crop to the roi
crop_img = img[y:y+h,x:x+w]
cv2.imwrite("crop.jpg",crop_img)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读