Python?第三方opencv庫(kù)實(shí)現(xiàn)圖像分割處理
前言
所需要安裝的庫(kù)有:
pip install opencv-python
pip install matplotlib
Python接口幫助文檔網(wǎng)址:https://docs.opencv.org/4.5.2/d6/d00/tutorial_py_root.html
本文所用到的圖片素材:
首先,導(dǎo)入所用到的庫(kù):
import cv2 import os,shutil from matplotlib import pyplot as plt
1.加載圖片
注意:這里在傳入圖像路徑時(shí),路徑中不能包含有中文名,否則會(huì)報(bào)錯(cuò)?。。?/p>
###1,加載圖片 filepath = './testImage.png' ###圖像路徑,注意:這里的路徑不能包含有中文名 img = cv2.imread(filepath) cv2.imshow('Orignal img', img) ###顯示圖片 cv2.waitKey(0) ###防止一閃而過(guò),是一個(gè)鍵盤(pán)綁定函數(shù)(0表示按下任意鍵終止)
2.對(duì)圖片做灰度處理
###2,將彩色圖片變?yōu)榛疑ㄟM(jìn)行灰度處理) img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) cv2.imshow('img_gray', img_gray) cv2.waitKey(0)
3.對(duì)圖片做二值化處理
thresh=220是自定義設(shè)定的閾值(通過(guò)分析print(img_gray)的圖像數(shù)據(jù)大概得到的),像素值大于220被置成了0,小于220的被置成了255。
maxval=與 THRESH_BINARY 和 THRESH_BINARY_INV 閾值一起使用的最大值,可理解是填充色,范圍為(0~255)。
type:參數(shù)類型閾值類型( cv2.THRESH_BINARY 大于閾值的部分被置為255,小于部分被置為0(黑白二值) cv2.THRESH_BINARY_INV 大于閾值部分被置為0,小于部分被置為255(黑白二值反轉(zhuǎn)——白黑) 等其它的類型...... )
###3,將圖片做二值化處理 ''' thresh=220是自定義設(shè)定的閾值(通過(guò)分析print(img_gray)的圖像數(shù)據(jù)大概得到的),像素值大于220被置成了0,小于220的被置成了255 maxval=與 THRESH_BINARY 和 THRESH_BINARY_INV 閾值一起使用的最大值,可理解是填充色,范圍為(0~255)。 type:參數(shù)類型閾值類型( cv2.THRESH_BINARY 大于閾值的部分被置為255,小于部分被置為0(黑白二值) cv2.THRESH_BINARY_INV 大于閾值部分被置為0,小于部分被置為255(黑白二值反轉(zhuǎn)——白黑) 等其它的類型...... ) ''' ret, img_inv = cv2.threshold(src=img_gray, thresh=220, maxval=255, type=cv2.THRESH_BINARY_INV) cv2.imshow('img_inv', img_inv) cv2.waitKey(0)
3.1.自定義閾值
###閾值對(duì)比(全局閾值(v = 127),自適應(yīng)平均閾值,自適應(yīng)高斯閾值) def threshContrast(): filepath = './testImage.png' img = cv2.imread(filepath) img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) img_gray = cv2.medianBlur(img_gray, 5) ret1, th1 = cv2.threshold(img_gray, 127, 255, cv2.THRESH_BINARY) th2 = cv2.adaptiveThreshold(img_gray, 255, cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY, 11, 2) th3 = cv2.adaptiveThreshold(img_gray, 255, cv2.ADAPTIVE_THRESH_GAUSSIAN_C, cv2.THRESH_BINARY, 11, 2) title = ['原始圖像(灰度)','全局閾值(v = 127)','自適應(yīng)平均閾值','自適應(yīng)高斯閾值'] images = [img_gray, th1, th2, th3] for i in range(4): plt.subplot(2, 2, i + 1), plt.imshow(images[i], 'gray') # plt.title(title[i]) ###plt繪圖時(shí)不能使用中文 plt.xticks([]), plt.yticks([]) plt.show()
4.提取輪廓
img_inv是尋找輪廓的圖像;
- cv2.RETR_EXTERNAL:表示只檢索極端外部輪廓;
- cv2.CHAIN_APPROX_SIMPLE:壓縮水平, 垂直和對(duì)角線方向的元素,只保留它們的端點(diǎn)坐標(biāo),例如,一個(gè)直立的矩形輪廓用 4 個(gè)點(diǎn)進(jìn)行編碼。
###4,提取輪廓 ''' https://docs.opencv.org/4.5.2/d4/d73/tutorial_py_contours_begin.html img_inv是尋找輪廓的圖像; cv2.RETR_EXTERNAL:表示只檢索極端外部輪廓; cv2.CHAIN_APPROX_SIMPLE:壓縮水平, 垂直和對(duì)角線方向的元素,只保留它們的端點(diǎn)坐標(biāo),例如,一個(gè)直立的矩形輪廓用 4 個(gè)點(diǎn)進(jìn)行編碼。 ''' contours,hierarchy = cv2.findContours(img_inv, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) print(f'檢測(cè)出輪廓數(shù)量有:{len(contours)}個(gè)') print('返回值為各層輪廓的索引:\n', hierarchy)
5.對(duì)輪廓畫(huà)矩形框
###5,找出每一個(gè)輪廓繪畫(huà)出的矩形位置 br = [] cntid = 0 for cnt in contours: '''cnt表示輸入的輪廓值,x,y, w, h 分別表示外接矩形的x軸和y軸的坐標(biāo),以及矩形的w寬和h高,''' x, y, w, h = cv2.boundingRect(cnt) cntid += 1 print(f'檢測(cè)出第{cntid}個(gè)輪廓畫(huà)出的矩形位置為:x={x},y={y},w={w},h={h}') br.append(cv2.boundingRect(cnt)) '''img表示輸入的需要畫(huà)的圖片(這里就是在原圖上繪制輪廓),cnt表示輸入的輪廓值,-1表示contours中輪廓的索引(這里繪制所有的輪廓),(0, 0, 255)表示rgb顏色——紅色,2表示線條粗細(xì)''' cv2.drawContours(img, [cnt], -1, (0, 0, 255), 2) cv2.imshow('cnt', img) cv2.waitKey(0) br.sort() ###將列表中的每一個(gè)元組里面的進(jìn)行升序排序(這里其實(shí)想的是按照對(duì)應(yīng)的x軸坐標(biāo)進(jìn)行升序)
對(duì)每個(gè)字符畫(huà)輪廓的過(guò)程(順序從右到左畫(huà),期間也有可能斷續(xù),如下圖)。
6.分割圖片并保存
###6,分割圖片并保存(這里對(duì)前面處理過(guò)的二值化圖片數(shù)據(jù)(img_inv)進(jìn)行分割) if not os.path.exists('./imageSplit'): os.mkdir('./imageSplit') else: shutil.rmtree('./imageSplit') os.mkdir('./imageSplit') for x,y,w,h in br: # print(x,y,w,h) # split_image = img_inv[y:y + h, x:x + w] split_image = img_inv[y - 2:y + h + 2, x - 2:x + w + 2] ###這樣分割感覺(jué)好看些 cv2.imshow('split_image', split_image) cv2.waitKey(0) save_filepath = './imageSplit/' filename = f'{x}.jpg' ###這里由每張圖片對(duì)應(yīng)的x軸坐標(biāo)命名 cv2.imwrite(save_filepath + filename, split_image) print(f'\033[31m{filename}圖片分割完畢!\033[0m')
這里是對(duì)前面處理過(guò)的二值化圖片數(shù)據(jù)(img_inv)進(jìn)行一個(gè)一個(gè)字符分割展示的過(guò)程。
這里是這行代碼的意思,下面的圖是手動(dòng)繪制的,太丑了,哈哈哈!?。?/p>
# split_image = img_inv[y:y + h, x:x + w]
7.查看分割圖片
最后,我們?cè)趐yplot上來(lái)查看我們分割圖片后的效果,也就終于完成了。
###7,用pyplot來(lái)查看我們分割完成后的圖片 imagefile_list = os.listdir('./imageSplit') imagefile_list.sort(key=lambda x: int(x[:-4])) for i in range(len(imagefile_list)): img = cv2.imread(f'./imageSplit/{imagefile_list[i]}') plt.subplot(1, len(imagefile_list), i + 1), plt.imshow(img, 'gray') plt.title(imagefile_list[i]) plt.xticks([]), plt.yticks([]) plt.show()
8.完整代碼
import cv2 import os,shutil from matplotlib import pyplot as plt ''' 這是使用文檔網(wǎng)址:https://docs.opencv.org/4.5.2/index.html 這是提供的Python接口教程網(wǎng)址:https://docs.opencv.org/4.5.2/d6/d00/tutorial_py_root.html ''' def imageSplit(): ###1,加載圖片 filepath = './testImage.png' ###圖像路徑,注意:這里的路徑不能包含有中文名 img = cv2.imread(filepath) cv2.imshow('Orignal img', img) ###顯示圖片 cv2.waitKey(0) ###防止一閃而過(guò),是一個(gè)鍵盤(pán)綁定函數(shù)(0表示按下任意鍵終止) ###2,將彩色圖片變?yōu)榛疑ㄟM(jìn)行灰度處理) img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) cv2.imshow('img_gray', img_gray) cv2.waitKey(0) ###3,將圖片做二值化處理 ''' thresh=220是自定義設(shè)定的閾值(通過(guò)分析print(img_gray)的圖像數(shù)據(jù)大概得到的),像素值大于220被置成了0,小于220的被置成了255 maxval=與 THRESH_BINARY 和 THRESH_BINARY_INV 閾值一起使用的最大值,可理解是填充色,范圍為(0~255)。 type:參數(shù)類型閾值類型( cv2.THRESH_BINARY 大于閾值的部分被置為255,小于部分被置為0(黑白二值) cv2.THRESH_BINARY_INV 大于閾值部分被置為0,小于部分被置為255(黑白二值反轉(zhuǎn)——白黑) 等其它的類型...... ) ''' ret, img_inv = cv2.threshold(src=img_gray, thresh=220, maxval=255, type=cv2.THRESH_BINARY_INV) cv2.imshow('img_inv', img_inv) cv2.waitKey(0) ###4,提取輪廓 ''' https://docs.opencv.org/4.5.2/d4/d73/tutorial_py_contours_begin.html img_inv是尋找輪廓的圖像; cv2.RETR_EXTERNAL:表示只檢索極端外部輪廓; cv2.CHAIN_APPROX_SIMPLE:壓縮水平, 垂直和對(duì)角線方向的元素,只保留它們的端點(diǎn)坐標(biāo),例如,一個(gè)直立的矩形輪廓用 4 個(gè)點(diǎn)進(jìn)行編碼。 ''' contours,hierarchy = cv2.findContours(img_inv, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) print(f'檢測(cè)出輪廓數(shù)量有:{len(contours)}個(gè)') print('返回值為各層輪廓的索引:\n', hierarchy) ###5,找出每一個(gè)輪廓繪畫(huà)出的矩形位置 br = [] cntid = 0 for cnt in contours: '''cnt表示輸入的輪廓值,x,y, w, h 分別表示外接矩形的x軸和y軸的坐標(biāo),以及矩形的w寬和h高,''' x, y, w, h = cv2.boundingRect(cnt) cntid += 1 print(f'檢測(cè)出第{cntid}個(gè)輪廓畫(huà)出的矩形位置為:x={x},y={y},w={w},h={h}') br.append(cv2.boundingRect(cnt)) '''img表示輸入的需要畫(huà)的圖片(這里就是在原圖上繪制輪廓),cnt表示輸入的輪廓值,-1表示contours中輪廓的索引(這里繪制所有的輪廓),(0, 0, 255)表示rgb顏色——紅色,2表示線條粗細(xì)''' cv2.drawContours(img, [cnt], -1, (0, 0, 255), 2) cv2.imshow('cnt', img) cv2.waitKey(0) br.sort() ###將列表中的每一個(gè)元組里面的進(jìn)行升序排序(這里其實(shí)想的是按照對(duì)應(yīng)的x軸坐標(biāo)進(jìn)行升序) ###6,分割圖片并保存(這里對(duì)前面處理過(guò)的二值化圖片數(shù)據(jù)(img_inv)進(jìn)行分割) if not os.path.exists('./imageSplit'): os.mkdir('./imageSplit') else: shutil.rmtree('./imageSplit') os.mkdir('./imageSplit') for x,y,w,h in br: # print(x,y,w,h) # split_image = img_inv[y:y + h, x:x + w] split_image = img_inv[y - 2:y + h + 2, x - 2:x + w + 2] ###這樣分割感覺(jué)好看些 cv2.imshow('split_image', split_image) cv2.waitKey(0) save_filepath = './imageSplit/' filename = f'{x}.jpg' ###這里由每張圖片對(duì)應(yīng)的x軸坐標(biāo)命名 cv2.imwrite(save_filepath + filename, split_image) print(f'\033[31m{filename}圖片分割完畢!\033[0m') cv2.destroyAllWindows() ###刪除所有窗口 ###7,用pyplot來(lái)查看我們分割完成后的圖片 imagefile_list = os.listdir('./imageSplit') imagefile_list.sort(key=lambda x: int(x[:-4])) for i in range(len(imagefile_list)): img = cv2.imread(f'./imageSplit/{imagefile_list[i]}') plt.subplot(1, len(imagefile_list), i + 1), plt.imshow(img, 'gray') plt.title(imagefile_list[i]) plt.xticks([]), plt.yticks([]) plt.show() print('\nperfect?。?!') ###閾值對(duì)比(全局閾值(v = 127),自適應(yīng)平均閾值,自適應(yīng)高斯閾值) def threshContrast(): filepath = './testImage.png' img = cv2.imread(filepath) img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) img_gray = cv2.medianBlur(img_gray, 5) ret1, th1 = cv2.threshold(img_gray, 127, 255, cv2.THRESH_BINARY) th2 = cv2.adaptiveThreshold(img_gray, 255, cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY, 11, 2) th3 = cv2.adaptiveThreshold(img_gray, 255, cv2.ADAPTIVE_THRESH_GAUSSIAN_C, cv2.THRESH_BINARY, 11, 2) title = ['原始圖像(灰度)','全局閾值(v = 127)','自適應(yīng)平均閾值','自適應(yīng)高斯閾值'] images = [img_gray, th1, th2, th3] for i in range(4): plt.subplot(2, 2, i + 1), plt.imshow(images[i], 'gray') # plt.title(title[i]) ###plt繪圖時(shí)不能使用中文 plt.xticks([]), plt.yticks([]) plt.show() if __name__ == '__main__': imageSplit() ###閾值對(duì)比 # threshContrast()
到此這篇關(guān)于Python 第三方opencv庫(kù)實(shí)現(xiàn)圖像分割處理的文章就介紹到這了,更多相關(guān)python圖片處理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Python3.7中安裝openCV庫(kù)的方法
- Python實(shí)現(xiàn)批量修改圖片格式和大小的方法【opencv庫(kù)與PIL庫(kù)】
- python環(huán)境下安裝opencv庫(kù)的方法
- python讀取并顯示圖片的三種方法(opencv、matplotlib、PIL庫(kù))
- Python下opencv庫(kù)的安裝過(guò)程及問(wèn)題匯總
- python實(shí)現(xiàn)圖片加文字水印OPenCV和PIL庫(kù)
- python計(jì)算機(jī)視覺(jué)OpenCV庫(kù)實(shí)現(xiàn)實(shí)時(shí)攝像頭人臉檢測(cè)示例
- 巧妙使用python?opencv庫(kù)玩轉(zhuǎn)視頻幀率
相關(guān)文章
詳解Django中異步任務(wù)之django-celery
這篇文章主要介紹了詳解Django中異步任務(wù)之django-celery,本文通過(guò)場(chǎng)景分析實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11python通過(guò)定義一個(gè)類實(shí)例作為ftp回調(diào)方法
這篇文章主要介紹了python通過(guò)定義一個(gè)類實(shí)例作為ftp回調(diào)方法,涉及Python中類與回調(diào)方法的使用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-05-05Python numpy和matlab的幾點(diǎn)差異介紹
這篇文章主要介紹了Python numpy和matlab的幾點(diǎn)差異,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07Django發(fā)送郵件和itsdangerous模塊的配合使用解析
這篇文章主要介紹了Django發(fā)送郵件和itsdangerous模塊的配合使用解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08python 匿名函數(shù)相關(guān)總結(jié)
這篇文章主要介紹了python 匿名函數(shù)的的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下2021-03-03Python multiprocessing 進(jìn)程間通信方式實(shí)現(xiàn)
本文主要介紹了Python multiprocessing 進(jìn)程間通信方式實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02python3.5 tkinter實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)
這篇文章主要為大家詳細(xì)介紹了python3.5 tkinter實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01詳解基于Transformer實(shí)現(xiàn)電影評(píng)論星級(jí)分類任務(wù)
這篇文章主要為大家介紹了詳解基于Transformer實(shí)現(xiàn)電影評(píng)論星級(jí)分類任務(wù)過(guò)程解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04