基于Python的车牌识别(切割及识别)

基于Python的车牌识别(切割及识别)

上一篇博文简单的分享车牌定位,这次,将定位出来的车牌进行分割并识别出该字符。

1、车牌定位及提取

可参考上一篇博文,下方是提取出来的车牌
在这里插入图片描述

2、车牌二值化

def split_char(image):
    # 改变车牌号大小
    image = cv2.resize(image, (445, 150))
    # 高斯模糊
    blurerd = cv2.GaussianBlur(image, (3, 3), 0, 0, cv2.BORDER_DEFAULT)
    # 图像转灰度
    gray = cv2.cvtColor(blurerd, cv2.COLOR_BGR2GRAY)

    kernel = np.ones((3, 3), np.uint8)
    # kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (5, 5))
    # img_opening = cv2.morphologyEx(gray,cv2.MORPH_CLOSE,kernel)
    # img_opening = cv2.addWeighted(gray,1,img_opening,-1,0)  #将两张图片相融合

    # 将灰度图像转换为二值化,设定阈值是100  (黑白照片)
    w=12 #分割图片的最小值
    A = 80
    P = 0.98
    while A<101:
        ret, img_thre = cv2.threshold(gray, A, 255, cv2.THRESH_BINARY_INV)
        # img_thre = cv2.erode(img_thre, kernel)

        cv2.imshow("threshold", img_thre)
        # cv2.imwrite(output_dir + '/' + 'img_thre' + '.jpg', img_thre)
        # cv2.waitKey(0)

在这里插入图片描述

3、分割

(1)分割主要采用的方法是投影,通过设置阈值将图片先水平分割(去掉上下水平线)

        # 分割图像
        white = []  # 记录每一列的白色像素总和
        black = []  # 记录每一列的黑色像素的总和
        height = img_thre.shape[0]
        width = img_thre.shape[1]
        white_max = 0
        black_max = 0
        # 计算每一行的黑白像素的总和
        for i in range(height):
            s = 0  # 这一行白色总数
            t = 0  # 这一行黑色总数
            for j in range(width):
                if img_thre[i][j] == 255:
                    s = s + 1
                if img_thre[i][j] == 0:
                    t = t + 1
            white_max = max(white_max, s)
            black_max 
  • 52
    点赞
  • 545
    收藏
    觉得还不错? 一键收藏
  • 62
    评论
Python中提取车牌号码的方法可以通过以下步骤实现: 1. 首先,加载已裁剪的车牌图像并显示它。可以使用OpenCV的cv2.imshow函数来显示图像。\[1\] 2. 接下来,使用pytesseract库的image_to_string函数将图像中的字符转换为字符串。可以将已裁剪的车牌图像作为参数传递给该函数,并指定语言为英语。\[1\] 3. 另一种方法是使用深度学习模型进行车牌识别。这个方法分为五个步骤:\[2\] a. 使用语义分割模型分割车牌。 b. 使用DeepLab V3+模型将车牌从图像中抠出来。 c. 将车牌字符一个个分割开。 d. 训练一个预训练模型来识别单个车牌字符。 e. 使用训练好的预训练模型识别分割好的字符,从而得到车牌号码。 4. 另一种方法是通过遍历轮廓来提取车牌号码。可以使用OpenCV的findContours函数找到图像中的轮廓,并使用approxPolyDP函数来近似轮廓的形状。然后,可以通过判断轮廓的角点数量来确定是否为车牌轮廓。最后,可以使用boundingRect函数获取车牌的坐标,并将其存储为新的图像。可以在原始图像上绘制车牌轮廓并显示出来。\[3\] 请注意,以上方法仅提供了一些常用的车牌识别方法,具体的实现可能因应用场景和需求而有所不同。 #### 引用[.reference_title] - *1* *3* [简直太逆天了,使用Python来检测和识别车牌号码(附代码)](https://blog.csdn.net/weixin_43373042/article/details/130234567)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [【python + opencv + pytorch】车牌提取、分割识别 pro版](https://blog.csdn.net/weixin_41645749/article/details/124599578)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 62
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值