用openCV和Python 實(shí)現(xiàn)圖片對比,并標(biāo)識出不同點(diǎn)的方式
最近項(xiàng)目中需要實(shí)現(xiàn)兩組圖片對比,并能將兩者的區(qū)別標(biāo)識出來。
在網(wǎng)上搜索一大堆找到一篇大神的文章,最終實(shí)現(xiàn)該功能,在這里記錄下:
想要實(shí)現(xiàn)此demo,首先我們得確保電腦上已安裝 openCV 和 Python 兩個(gè)工具以及scikit-image和imutils兩個(gè)庫:
安裝方法,在這里不多說,我安裝的是Python3.6 和openCV2,安裝方法網(wǎng)上自行百度谷歌;
進(jìn)入正題:
新建一個(gè)新的Python文件并命名為copmarePicture.py,寫入下面的代碼:
from skimage.measure import compare_ssim #~ import skimage as ssim import argparse import imutils import cv2
加載兩張圖片并將他們轉(zhuǎn)換為灰度:
imageA = cv2.imread("D:/111test/111.png") imageB = cv2.imread("D:/111test/444.png") grayA = cv2.cvtColor(imageA,cv2.COLOR_BGR2GRAY) grayB = cv2.cvtColor(imageB,cv2.COLOR_BGR2GRAY)
接下來,計(jì)算兩個(gè)灰度圖像之間的結(jié)構(gòu)相似度指數(shù):
(score,diff) = compare_ssim(grayA,grayB,full = True) diff = (diff *255).astype("uint8") print("SSIM:{}".format(score))
找到不同點(diǎn)的輪廓以致于我們可以在被標(biāo)識為“不同”的區(qū)域周圍放置矩形:
thresh = cv2.threshold(diff,0,255,cv2.THRESH_BINARY_INV | cv2.THRESH_OTSU)[1] cnts = cv2.findContours(thresh.copy(),cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE) cnts = cnts[0] if imutils.is_cv2() else cnts[1]
找到一系列區(qū)域,在區(qū)域周圍放置矩形:
for c in cnts: (x,y,w,h) = cv2.boundingRect(c) cv2.rectangle(imageA,(x,y),(x+w,y+h),(0,0,255),2) cv2.rectangle(imageB,(x,y),(x+w,y+h),(0,0,255),2)
用cv2.imshow 展現(xiàn)最終對比之后的圖片, cv2.imwrite 保存最終的結(jié)果圖片
cv2.imshow("Modified",imageB) cv2.imwrite("haha2.png",imageB) cv2.waitKey(0)
到這已經(jīng)實(shí)現(xiàn)兩張圖片的對比并標(biāo)識出不同。結(jié)果如下所示:(圖1圖2對比,圖3為對標(biāo)結(jié)果
以上這篇用openCV和Python 實(shí)現(xiàn)圖片對比,并標(biāo)識出不同點(diǎn)的方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Opencv實(shí)現(xiàn)眼睛控制鼠標(biāo)的實(shí)踐
本文主要介紹了Opencv實(shí)現(xiàn)眼睛控制鼠標(biāo)的實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02單身狗福利?Python爬取某婚戀網(wǎng)征婚數(shù)據(jù)
今天我就當(dāng)回媒婆,給男性程序員來點(diǎn)福利.今天目標(biāo)爬取征婚網(wǎng)上呈現(xiàn)出來的女生信息保存成excel表格供大家篩選心儀的女生,需要的朋友可以參考下2021-06-06Python獲取CPU、內(nèi)存使用率以及網(wǎng)絡(luò)使用狀態(tài)代碼
這篇文章主要介紹了Python獲取CPU使用率、內(nèi)存使用率、網(wǎng)絡(luò)使用狀態(tài)的相關(guān)代碼,對此有需要的朋友一起測試下。2018-02-02Python實(shí)現(xiàn)簡單的ui界面的設(shè)計(jì)步驟(適合小白)
當(dāng)我們書寫一個(gè)python程序時(shí),我們在控制臺輸入信息時(shí),往往多有不便,并且為了更加美觀且直觀的方式輸入控制命令,我們常常設(shè)計(jì)一個(gè)ui界面,這樣就能方便執(zhí)行相關(guān)功能,如計(jì)算器、日歷等界面,本博客是為了給ui設(shè)計(jì)的小白進(jìn)行講解,需要的朋友可以參考下2024-07-07Python中常用的統(tǒng)計(jì)檢驗(yàn)代碼分享
統(tǒng)計(jì)檢驗(yàn)是數(shù)據(jù)分析中的重要工具,用于檢驗(yàn)數(shù)據(jù)集中的差異、關(guān)聯(lián)和分布等統(tǒng)計(jì)性質(zhì),本文為大家整理了常見的統(tǒng)計(jì)檢驗(yàn)方法,希望對大家有所幫助2024-01-01使用coverage統(tǒng)計(jì)python web項(xiàng)目代碼覆蓋率的方法詳解
這篇文章主要介紹了使用coverage統(tǒng)計(jì)python web項(xiàng)目代碼覆蓋率的方法,詳細(xì)分析了coverage的安裝以及coverage命令統(tǒng)計(jì)py文件相關(guān)操作技巧,需要的朋友可以參考下2019-08-08Python+DeOldify實(shí)現(xiàn)老照片上色功能
DeOldify是一種技術(shù),以彩色和恢復(fù)舊的黑白圖像,甚至電影片段。它是由一個(gè)叫Jason?Antic的人開發(fā)和更新的。本文將利用DeOldify實(shí)現(xiàn)老照片上色功能,感興趣的可以了解一下2022-06-06