佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 詳解Python+opencv裁剪/截取圖片的幾種方式

詳解Python+opencv裁剪/截取圖片的幾種方式

熱門標(biāo)簽:Win7旗艦版 語音系統(tǒng) 企業(yè)做大做強(qiáng) 百度AI接口 電話運營中心 硅谷的囚徒呼叫中心 呼叫中心市場需求 客戶服務(wù)

前言

在計算機(jī)視覺任務(wù)中,如圖像分類,圖像數(shù)據(jù)集必不可少。自己采集的圖片往往存在很多噪聲或無用信息會影響模型訓(xùn)練。因此,需要對圖片進(jìn)行裁剪處理,以防止圖片邊緣無用信息對模型造成影響。本文介紹幾種圖片裁剪的方式,供大家參考。

一、手動單張裁剪/截取

selectROI:選擇感興趣區(qū)域,邊界框框選x,y,w,h

selectROI(windowName, img, showCrosshair=None, fromCenter=None):
. 參數(shù)windowName:選擇的區(qū)域被顯示在的窗口的名字
. 參數(shù)img:要在什么圖片上選擇ROI
. 參數(shù)showCrosshair:是否在矩形框里畫十字線.
. 參數(shù)fromCenter:是否是從矩形框的中心開始畫

要截取的原圖如下:


截取效果如下:


截取之后按回車Enter保存:


完整代碼如下:

import cv2

img = 'D:/anaconda3/JupyterNotebookFile/images/dogs_and_cats.jpg'
img = cv2.imread(img)
cv2.imshow('original', img)

# 選擇ROI
roi = cv2.selectROI(windowName="original", img=img, showCrosshair=True, fromCenter=False)
x, y, w, h = roi
print(roi)

# 顯示ROI并保存圖片
if roi != (0, 0, 0, 0):
    crop = img[y:y+h, x:x+w]
    cv2.imshow('crop', crop)
    cv2.imwrite('D:/anaconda3/JupyterNotebookFile/images/dogs_and_cats_crop.jpg', crop)
    print('Saved!')

# 退出
cv2.waitKey(0)
cv2.destroyAllWindows()

讀者根據(jù)自己的圖片目錄修改目標(biāo)圖片目錄和要寫入的目錄。

二、根據(jù)圖片的位置坐標(biāo)進(jìn)行裁剪/截取


這是一張432×432大小的圖片,左上角坐標(biāo)為(0,0).

import cv2
im = cv2.imread('圖片路徑')

在用cv2.imread()默認(rèn)讀取三通道RGB圖像后,會返回一個三維數(shù)組。同時,可用im[h,w]的形式來截取圖片中的某個部分。比如中間柴犬的位置相對左上角坐標(biāo)原點為,從上到下為190-380,從左往右為180-260。這樣就可以通過坐標(biāo)的相對位置來裁剪/截取目標(biāo)圖像了。

完整代碼如下:

import cv2
import os

file_path = 'D:/anaconda3/JupyterNotebookFile/images/dogs_and_cats.jpg'
out_file_name = 'dogs_and_cats_cropp'

im = cv2.imread(file_path)
im = im[190:380,180:260]
save_path = r'D:/anaconda3/JupyterNotebookFile/images'
save_path_file = os.path.join(save_path,out_file_name+'.jpg')
cv2.imwrite(save_path_file,im)

截取后的圖片效果:

若很多個圖片數(shù)據(jù)具有相似的位置,則可以通過遍歷文件的方式批量裁剪/截取,代碼如下:

import cv2
import os

def clip_image(filelist,i,im_path):  
	'''
	filelist:文件夾路徑
	i:批量保存的圖片文件名,用數(shù)字表示
	im_path:圖片路徑
	'''  
    for file in filelist:
        file_path=os.path.join(im_path,file)
        im=cv2.imread(file_path)
        #[h,w]根據(jù)自己圖片中目標(biāo)的位置修改
        im=im[190:380,180:260]                      
        save_path = r'D:/anaconda3/JupyterNotebookFile/images'
        save_path_file = os.path.join(save_path,out_file_name+'.jpg')           
        cv2.imwrite(save_path_file,im)            
        i=i+1

傳參并測試:筆者用的jupyter notebook,其他編譯器寫在main()中

i=0
im_path = r'D:/anaconda3/JupyterNotebookFile/images/dogs_and_cats.jpg'
filelist = os.listdir(im_path)
clip_image(filelist,i,im_path)

三、、用YOLO目標(biāo)檢測框裁剪并批量保存

同一類圖片數(shù)據(jù)具有相似的特征,標(biāo)注少量的圖片訓(xùn)練YOLO提升其定位目標(biāo)的能力,可以將所有的測試數(shù)據(jù)根據(jù)YOLO檢測結(jié)果裁剪,并將結(jié)果保存用于其他分類任務(wù)中。

代碼如下:

from PIL import Image

from yolo import YOLO
import os
import cv2
import numpy as np
yolo = YOLO()

'''
yolo摳圖,截取目標(biāo)
'''
j=0
#預(yù)測圖片所在路徑
path = 'E:/crop_all'
imgdir = os.listdir(path)
for dir in imgdir:
    img_path = os.path.join(path,dir)
    image = Image.open(img_path)
    #print(image)
    crop_image = cv2.imread(img_path)
    #print(crop_image[0])
    boxes = yolo.detect_image(image)
    #print(boxes)

    top = boxes[0][0]
    left = boxes[0][1]
    bottom = boxes[0][2]
    right = boxes[0][3]

    top = top - 5
    left = left - 5
    bottom = bottom + 5
    right = right + 5

    # 左上角點的坐標(biāo)
    top = int(max(0, np.floor(top + 0.5).astype('int32')))
    left = int(max(0, np.floor(left + 0.5).astype('int32')))
    # 右下角點的坐標(biāo)
    bottom = int(min(np.shape(image)[0], np.floor(bottom + 0.5).astype('int32')))
    right = int(min(np.shape(image)[1], np.floor(right + 0.5).astype('int32')))


    croped_region = crop_image[top:bottom, left:right]
    
    #裁剪圖片存放目錄
    baocun = r'E:/crop_all_finish'
    save_path = os.path.join(baocun, str(j) + '.bmp')
    cv2.imwrite(save_path, croped_region)
    j = j + 1

截取效果如下:

總結(jié)

  • 方法一適合少量圖片裁剪或做測試時使用,無法批量裁剪。
  • 方法二適合多個樣本中的目標(biāo)具有相似的位置,可以批量裁剪但是若位置不相似則不適用。
  • 方法三用形態(tài)學(xué)手法獲取輪廓再根據(jù)bounding box裁剪,可以批量處理,但是裁剪效果一般,能不能得到物體全看之前的輪廓獲取的是否清晰,但并不是每個圖片中的目標(biāo)都能清晰地獲取到輪廓。
  • 方法四用YOLO也是根據(jù)boundingbox裁剪,可以批量處理但是需要人工標(biāo)注成本,而且該成本根據(jù)模型的準(zhǔn)確性略有起伏,但由于yolo訓(xùn)練很快,所以該方法是個不錯的裁剪圖片的手段。

到此這篇關(guān)于詳解Python+opencv裁剪/截取圖片的幾種方式的文章就介紹到這了,更多相關(guān)opencv裁剪圖片內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python OpenCV實現(xiàn)裁剪并保存圖片
  • python通過opencv實現(xiàn)圖片裁剪原理解析
  • Python實現(xiàn)圖片裁剪的兩種方式(Pillow和OpenCV)
  • Python OpenCV圖像指定區(qū)域裁剪的實現(xiàn)
  • 使用Python和OpenCV檢測圖像中的物體并將物體裁剪下來
  • python opencv對圖像進(jìn)行旋轉(zhuǎn)且不裁剪圖片的實現(xiàn)方法
  • python opencv實現(xiàn)目標(biāo)區(qū)域裁剪功能

標(biāo)簽:山西 長沙 崇左 安康 海南 喀什 濟(jì)南 山西

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解Python+opencv裁剪/截取圖片的幾種方式》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    盐津县| 大同市| 五台县| 江永县| 大冶市| 丹江口市| 广德县| 北辰区| 富顺县| 兰西县| 扎兰屯市| 民权县| 喜德县| 天津市| 沛县| 凤阳县| 莱阳市| 福泉市| 神木县| 萨迦县| 余庆县| 安国市| 太保市| 台东县| 奇台县| 庄浪县| 郧西县| 台安县| 日土县| 朔州市| 那坡县| 遂川县| 普兰店市| 朝阳区| 台前县| 娱乐| 金门县| 巴塘县| 富平县| 碌曲县| 图木舒克市|