python opencv如何實現目標區域裁剪功能
這個任務是自己在專案中資料處理的一部分內容,待處理的圖片如下所示:
我需要將目標區域給裁剪出來,要不然在後期訓練網路的時候整幅影像過大,且目標區域過小,得到結果不好,還會加劇計算量。在網上找了各個大佬的部落格看,沒找到合適的,便自己動手寫了,順便自己的小破站剛搭建起來,記錄一下自己的思路。
思路
去尋找目標區域的最左邊,最右邊,最上面和最下面的畫素點,取到座標資訊以後用CV2的裁剪一下就可以實現了。
難點
資料總共是11952張圖片,每張圖片是1024*768大小的,依次去遍歷的話擔心太費時間了,結果還好,影像中黑色的畫素點值為0,計算量比想象的要小很多。
import cv2 """ 使用OpenCV擷取圖片 """ def search(path): left = 1024 right = 0 upper = 768 lower = 0 img = cv2.imread(path)[:,:,0] # print(img.shape) for i in range(768): for j in range(1024): if img[i,j] != 0 : # print(img[i,j]) left = min(j,left) right = max(j,right) lower = max(i,lower) upper = min(i,upper) return (left,upper,right,lower) def image_cut_save(path, left, upper, right, lower, save_path): """ 所截區域圖片儲存 :param path: 圖片路徑 :param left: 區塊左上角位置的畫素點離圖片左邊界的距離 :param upper:區塊左上角位置的畫素點離圖片上邊界的距離 :param right:區塊右下角位置的畫素點離圖片左邊界的距離 :param lower:區塊右下角位置的畫素點離圖片上邊界的距離 故需滿足:lower > upper、right > left :param save_path: 所截圖片儲存位置 """ img = cv2.imread(path) # 開啟影像 cropped = img[upper:lower, left:right] # 儲存擷取的圖片 cv2.imwrite(save_path, cropped) if __name__ == '__main__': root_path = r'原圖片的路徑' save_path = r'裁剪後的圖片儲存的路徑' images = os.listdir(root_path) for image in images: # print(image) pic_path = os.path.join(root_path,image) # print(pic_path) pic_save_dir_path = os.path.join(save_path,image) print(pic_save_dir_path) left, upper, right, lower = search(pic_path) # show_cut(pic_path, left, upper, right, lower) image_cut_save(pic_path, left, upper, right, lower, pic_save_dir_path)
裁剪後的影像如下
以上就是python opencv實現目標區域裁剪功能的方法。更多Python學習指路:
本文轉載於指令碼之家,如有侵犯聯絡作者修改。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/4830/viewspace-2828694/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 深入學習OpenCV檢測及分割影象的目標區域OpenCV
- OpenCV----實現目標識別與分割OpenCV
- 【目標區域捕獲-2】目標區域捕獲簡介
- 利用 clip-path 實現動態區域裁剪
- Python+OpenCV目標跟蹤實現基本的運動檢測PythonOpenCV
- 混合高斯模型實現運動目標檢測(OpenCV內建實現)模型OpenCV
- [影象處理] Python+OpenCV實現車牌區域識別及Sobel運算元PythonOpenCV
- 單目標定:從理論到OpenCV實踐OpenCV
- 目標匹配:匈牙利演算法的python實現演算法Python
- Python OpenCV 3 使用背景減除進行目標檢測PythonOpenCV
- SafeTpack ——基於AURIXTM 2G實現功能安全目標
- SafeTpack — 基於 AURIX™ 2G 實現功能安全目標
- 如何實現共享螢幕標註功能?
- python OpenCV加法操作的實現PythonOpenCV
- python的爬蟲功能如何實現Python爬蟲
- 如何使用Python 實現秒錶功能?Python
- 如何用OpenCV在Python中實現人臉檢測OpenCVPython
- Qt加Opencv實現 梯度矯正 功能QTOpenCV梯度
- 檢視使用者所在區域,IP定位離線庫助您實現精準銷售目標
- opencv的目標跟蹤演算法OpenCV演算法
- [譯]使用 Python 實現接縫裁剪演算法Python演算法
- SICP:賦值和區域性狀態(Python實現)賦值Python
- android實現拍照、相簿選圖、裁剪功能,相容7.0以及小米Android
- 基於canvas剪輯區域功能實現橡皮擦效果Canvas
- python基於opencv 實現影像時鐘PythonOpenCV
- Flutter 區域性路由實現Flutter路由
- 品牌如何建立軟文營銷策略實現業務目標
- 雙目標定與三維計算:從理論到OpenCV實踐OpenCV
- Devops 原始思想 所要實現的目標dev
- python如何安裝OpenCV?PythonOpenCV
- 百度地圖BMap實現在行政區域內做標註地圖
- python如何實現簡單的爬蟲功能?Python學習教程!Python爬蟲
- 張正友標定Opencv實現、標定流程以及影像座標轉為世界座標OpenCV
- 如何用Python實現iPhone X的人臉解鎖功能?PythoniPhone
- 多目標遺傳演算法NSGA-Ⅱ與其Python實現多目標投資組合優化問題演算法Python優化
- python標準庫目錄Python
- ADAMoracle的目標是連線現實世界資料與區塊鏈系統Oracle區塊鏈
- 利用指標實現strncmp函式功能指標函式