校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

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

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

熱門標簽:遼寧400電話辦理多少錢 溫州旅游地圖標注 荊州云電銷機器人供應商 幫人做地圖標注收費算詐騙嗎 蘇州電銷機器人十大排行榜 江蘇房產電銷機器人廠家 電信營業廳400電話申請 悟空智電銷機器人6 外呼不封號系統

前言

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

一、手動單張裁剪/截取

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

selectROI(windowName, img, showCrosshair=None, fromCenter=None):
. 參數windowName:選擇的區域被顯示在的窗口的名字
. 參數img:要在什么圖片上選擇ROI
. 參數showCrosshair:是否在矩形框里畫十字線.
. 參數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()

讀者根據自己的圖片目錄修改目標圖片目錄和要寫入的目錄。

二、根據圖片的位置坐標進行裁剪/截取


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

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

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

完整代碼如下:

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)

截取后的圖片效果:

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

import cv2
import os

def clip_image(filelist,i,im_path):  
	'''
	filelist:文件夾路徑
	i:批量保存的圖片文件名,用數字表示
	im_path:圖片路徑
	'''  
    for file in filelist:
        file_path=os.path.join(im_path,file)
        im=cv2.imread(file_path)
        #[h,w]根據自己圖片中目標的位置修改
        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目標檢測框裁剪并批量保存

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

代碼如下:

from PIL import Image

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

'''
yolo摳圖,截取目標
'''
j=0
#預測圖片所在路徑
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

    # 左上角點的坐標
    top = int(max(0, np.floor(top + 0.5).astype('int32')))
    left = int(max(0, np.floor(left + 0.5).astype('int32')))
    # 右下角點的坐標
    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

截取效果如下:

總結

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

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

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

標簽:臺灣 宿遷 黃山 欽州 喀什 景德鎮 濟南 三沙

巨人網絡通訊聲明:本文標題《詳解Python+opencv裁剪/截取圖片的幾種方式》,本文關鍵詞  詳解,Python+opencv,裁剪,截取,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解Python+opencv裁剪/截取圖片的幾種方式》相關的同類信息!
  • 本頁收集關于詳解Python+opencv裁剪/截取圖片的幾種方式的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    欧美日韩大陆在线| 国产无遮挡一区二区三区毛片日本| 极品少妇xxxx精品少妇偷拍| 精品亚洲aⅴ乱码一区二区三区| 国产精品正在播放| 欧美午夜片在线看| 精品少妇一区二区三区视频免付费| 欧美麻豆精品久久久久久| 久久久亚洲精品石原莉奈| 亚洲精品高清视频在线观看| 美国毛片一区二区| 国模套图日韩精品一区二区| 99视频精品在线| 在线播放亚洲一区| 亚洲人成精品久久久久久| 亚洲永久免费av| 国产91高潮流白浆在线麻豆| 6080日韩午夜伦伦午夜伦| 国产丝袜美腿一区二区三区| 国产精品久久一级| 中文字幕在线免费不卡| 欧美性生交片4| 精品视频在线视频| 日韩一区二区中文字幕| 国产精品不卡一区| 日本视频一区二区三区| 成人av午夜影院| 日韩一区二区电影在线| 亚洲综合一区二区| 成人蜜臀av电影| 日韩女优电影在线观看| 亚洲一区二区三区四区五区中文| 美女视频免费一区| 欧美一级欧美三级在线观看| 国产女人18毛片水真多成人如厕| 日韩高清一区二区| 欧美日韩成人高清| 亚洲美女精品一区| 免费的国产精品| 欧美三级日本三级少妇99| ...中文天堂在线一区| 国产·精品毛片| 欧美一区二区三区婷婷月色| 亚洲成人免费观看| 欧美日韩免费不卡视频一区二区三区| 国产精品乱人伦| 成人免费看的视频| 久久九九99视频| 国产毛片精品一区| 精品成人a区在线观看| 男人操女人的视频在线观看欧美| 不卡的电影网站| 国产精品麻豆久久久| 成人高清视频免费观看| 亚洲国产激情av| 激情亚洲综合在线| 精品播放一区二区| 精品制服美女久久| 国产欧美一区二区精品久导航| 精品一区二区三区在线观看| 亚洲精品一区二区三区香蕉 | 一区二区在线观看免费视频播放| 成人精品gif动图一区| 欧美xxxxxxxxx| 粉嫩av一区二区三区| 中文字幕欧美激情一区| www.欧美色图| 亚洲在线中文字幕| 日韩三级视频在线看| 国产麻豆精品theporn| 国产精品国产自产拍在线| 97超碰欧美中文字幕| 丝袜脚交一区二区| 欧美精品一区二区高清在线观看| 91浏览器在线视频| 一区二区视频在线看| 日韩视频在线永久播放| youjizz久久| 久久精品99久久久| 夜夜嗨av一区二区三区网页| 久久久综合视频| 欧美精品久久99久久在免费线 | 精品国产一区二区三区久久久蜜月 | 99在线精品一区二区三区| 日韩国产欧美一区二区三区| 国产精品人成在线观看免费 | 免费人成黄页网站在线一区二区| 久久久九九九九| 欧美精品高清视频| 99久久精品国产网站| 蜜臀久久99精品久久久画质超高清| 中文av一区二区| 日韩一级大片在线| 91黄色激情网站| www.欧美色图| 国产精品77777| 久久69国产一区二区蜜臀| 亚洲国产日韩在线一区模特| 国产精品丝袜黑色高跟| 欧美成人三级电影在线| 欧美日韩视频在线观看一区二区三区 | 色综合久久综合网| 国产黄人亚洲片| 激情综合网av| 国产在线视频一区二区三区| 亚洲一区二区三区四区在线观看| 国产精品国产自产拍高清av| 国产亚洲精品bt天堂精选| 日韩欧美在线123| 在线播放日韩导航| 欧美人妇做爰xxxⅹ性高电影| 色综合咪咪久久| 色综合久久中文字幕| 色先锋资源久久综合| 91理论电影在线观看| 一本大道久久a久久精二百| 91免费在线播放| 色狠狠综合天天综合综合| 色综合一个色综合亚洲| 91猫先生在线| 一本到高清视频免费精品| 色婷婷久久久综合中文字幕| 91麻豆国产香蕉久久精品| 91蝌蚪porny| 欧美三级乱人伦电影| 欧美日韩国产经典色站一区二区三区| 色94色欧美sute亚洲线路一久| 91蜜桃婷婷狠狠久久综合9色| 91亚洲资源网| 欧美日韩亚洲高清一区二区| 91麻豆精品国产91久久久使用方法| 欧美日韩精品一区二区三区蜜桃| 91精品1区2区| 欧美日韩mp4| 欧美大尺度电影在线| 久久久综合激的五月天| 中文字幕精品一区 | 日韩女优电影在线观看| 久久久久久亚洲综合| 国产精品乱码人人做人人爱| 亚洲女同一区二区| 视频精品一区二区| 国产精品一区二区在线看| 91色在线porny| 欧美一区二区三区性视频| 久久久久久日产精品| 亚洲人123区| 蜜臀av性久久久久av蜜臀妖精| 国产一区二区三区高清播放| 成人app网站| 3atv一区二区三区| 亚洲国产精品精华液ab| 亚洲综合偷拍欧美一区色| 蜜桃视频第一区免费观看| 成人在线视频一区| 欧美日韩综合一区| 国产欧美日韩亚州综合| 一区av在线播放| 国产精品一区二区三区乱码| 91成人国产精品| 欧美国产一区二区| 日韩黄色免费电影| 高清不卡一区二区| 91麻豆精品国产91久久久使用方法| 欧美激情一区不卡| 日本亚洲欧美天堂免费| 99精品视频在线播放观看| 日韩精品一区二区三区四区| 亚洲免费观看高清| 国产在线国偷精品产拍免费yy| 在线精品视频免费观看| 国产三级欧美三级日产三级99 | 免费视频一区二区| 在线免费av一区| 日本一区二区成人| 精品一区二区免费在线观看| 91福利在线看| 日韩美女视频一区二区| 丁香激情综合五月| 久久午夜色播影院免费高清| 毛片av中文字幕一区二区| 欧洲生活片亚洲生活在线观看| 久久久精品免费网站| 美腿丝袜亚洲一区| 欧美高清性hdvideosex| 亚洲欧美电影院| www.亚洲国产| 国产欧美日韩在线| 成人禁用看黄a在线| 久久久久久一级片| 国模少妇一区二区三区| 日韩欧美一级特黄在线播放| 天天影视涩香欲综合网| 欧美日韩综合色| 亚洲国产综合色| 欧美午夜一区二区三区| 一区二区免费在线| 欧美视频你懂的| 一区二区三区四区亚洲| 欧美性做爰猛烈叫床潮|