python+opencv實(shí)現(xiàn)文字顏色識別與標(biāo)定功能
最近接了一個比較簡單的圖像處理的單子,花了一點(diǎn)時間隨便寫了一下:
數(shù)據(jù)集客戶沒有是自己隨便創(chuàng)建的:
程序如下:
""" Code creation time:September 11, 2021 Author:PanBo Realize function:It mainly realizes the recognition and calibration of fonts with different colors """ import numpy as np import cv2 as cv font = cv.FONT_HERSHEY_SIMPLEX lower_red = np.array([0, 120, 120]) hight_red = np.array([10, 255, 255]) # lower_black = np.array([0, 0, 0]) height_black = np.array([144, 144, 144]) lower_yellow = np.array([10, 230, 230]) height_yellow = np.array([35, 255, 255]) frame = cv.imread("test.png") cv.namedWindow("test_image", cv.WINDOW_AUTOSIZE) cv.imshow('test_image', frame) img_hsv = cv.cvtColor(frame, cv.COLOR_BGR2HSV) mask_red = cv.inRange(img_hsv, lower_red, hight_red) mask_black = cv.inRange(img_hsv, lower_black, height_black) mask_yellow = cv.inRange(img_hsv, lower_yellow, height_yellow) cv.namedWindow("mask_red", cv.WINDOW_AUTOSIZE) cv.imshow("mask_red", mask_red) cv.namedWindow("mask_black", cv.WINDOW_AUTOSIZE) cv.imshow("mask_black", mask_black) cv.namedWindow("mask_yellow", cv.WINDOW_AUTOSIZE) cv.imshow("mask_yellow", mask_yellow) kernel = cv.getStructuringElement(cv.MORPH_RECT, (3, 3)) mask_yellow = cv.morphologyEx(mask_yellow, cv.MORPH_OPEN, kernel) cv.namedWindow("mask_yellow_open", cv.WINDOW_AUTOSIZE) cv.imshow("mask_yellow_open", mask_yellow) mask_yellow = cv.morphologyEx(mask_yellow, cv.MORPH_CLOSE, kernel) cv.namedWindow("mask_yellow_close", cv.WINDOW_AUTOSIZE) cv.imshow("mask_yellow_close", mask_yellow) mask_black = cv.medianBlur(mask_black, 3) mask_red = cv.medianBlur(mask_red, 3) mask_yellow = cv.medianBlur(mask_yellow, 3) # cv.imshow(" ", mask_green) cnts1, hierarchy1 = cv.findContours(mask_black, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_NONE) cnts2, hierarchy2 = cv.findContours(mask_red, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_NONE) cnts3, hierarchy3 = cv.findContours(mask_yellow, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_NONE) for cnt in cnts1: (x, y, w, h) = cv.boundingRect(cnt) cv.rectangle(frame, (x, y), (x + w, y + h), (0, 0, 0), 2) cv.putText(frame, 'black', (x, y-5), font, 0.7, (0, 0, 25),2) for cnt in cnts2: (x, y, w, h) = cv.boundingRect(cnt) cv.rectangle(frame, (x, y), (x + w, y + h), (0, 0, 255), 2) cv.putText(frame, 'red', (x, y - 5), font, 0.7, (0, 0, 255), 2) for cnt in cnts3: (x, y, w, h) = cv.boundingRect(cnt) cv.rectangle(frame, (x, y), (x + w, y + h), (0, 0, 255), 2) cv.putText(frame, 'yellow', (x, y - 5), font, 0.7, (0, 0, 255), 2) cv.namedWindow("output", cv.WINDOW_AUTOSIZE) cv.imshow("output", frame) cv.waitKey(0)
首先給定字體顏色的上下閾值,然后提取出紅色、黑色以及黃色的字體如下所示:
檢測出原始圖像中存在的紅色字體的為四和五
檢車出原始圖像中存在的黑色字體是一和大
檢測出原始圖像中存在黃色字體的是七和九
但是通過yellow字體檢測的過程中發(fā)現(xiàn)有一些椒鹽噪聲需要去剔除,因此做了一下中值濾波
但是效果不好有做一個形態(tài)學(xué)操作——開操作,結(jié)果如下:
但是發(fā)現(xiàn)了七和九發(fā)生了斷層現(xiàn)象如果進(jìn)行矩形標(biāo)定的話會出現(xiàn)兩個矩形,因此又做了一下形態(tài)學(xué)操作中的——閉操作結(jié)果如下:
經(jīng)過閉操作我們發(fā)現(xiàn)七處的裂縫沒有了但是九還是有,這個是由于設(shè)置的yellow上下閾值導(dǎo)致的。
后面進(jìn)行矩形標(biāo)定如下所示:
到此這篇關(guān)于python+opencv實(shí)現(xiàn)文字顏色識別與標(biāo)定的文章就介紹到這了,更多相關(guān)python opencv文字顏色識別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python實(shí)現(xiàn)的根據(jù)文件名查找數(shù)據(jù)文件功能示例
這篇文章主要介紹了Python實(shí)現(xiàn)的根據(jù)文件名查找數(shù)據(jù)文件功能,涉及Python針對文件與目錄的遍歷、查詢等相關(guān)操作技巧,需要的朋友可以參考下2018-05-05關(guān)于對python中進(jìn)程的幾個概念理解
進(jìn)程由程序,數(shù)據(jù)和進(jìn)程控制塊組成,是正在執(zhí)行的程,程序的一次執(zhí)行過程,是資源調(diào)度的基本單位,下面這篇文章主要給大家介紹了關(guān)于對python中進(jìn)程的幾個概念理解,需要的朋友可以參考下2021-10-10用python3讀取python2的pickle數(shù)據(jù)方式
今天小編就為大家分享一篇用python3讀取python2的pickle數(shù)據(jù)方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12Python實(shí)現(xiàn)8個概率分布公式的方法詳解
在本文中,我們將介紹一些常見的分布(均勻分布、高斯分布、對數(shù)正態(tài)分布等)并通過Python代碼進(jìn)行可視化以直觀地顯示它們,感興趣的可以學(xué)習(xí)一下2022-05-05Python中import導(dǎo)入不同目錄的模塊方法詳解
這篇文章主要介紹了Python中import導(dǎo)入不同目錄的模塊方法詳解,需要的朋友可以參考下2020-02-02python連接mongodb操作數(shù)據(jù)示例(mongodb數(shù)據(jù)庫配置類)
這篇文章主要介紹了python連接mongodb操作數(shù)據(jù)示例,主要包括插入數(shù)據(jù)、更新數(shù)據(jù)、查詢數(shù)據(jù)、刪除數(shù)據(jù)等2013-12-12