python實(shí)現(xiàn)人臉檢測(cè)的簡(jiǎn)單實(shí)例
OpenCV
OpenCV 是計(jì)算機(jī)視覺領(lǐng)域最受歡迎的開源庫(kù),起初它由 C/C ++ 編寫,現(xiàn)在用 Python 也能使用。
OpenCV 可以使用機(jī)器學(xué)習(xí)算法搜索圖像中的人臉。由于人臉比較復(fù)雜,所以并沒(méi)有一種簡(jiǎn)單的測(cè)試可以告訴我們它是否發(fā)現(xiàn)了人臉。但是,算法能夠匹配到數(shù)千個(gè)很小的模式和特征。算法會(huì)將識(shí)別人臉的任務(wù)分解為幾千個(gè)非常非常小的任務(wù),像這種很小的任務(wù),解決起來(lái)就比較容易了。這樣的微小任務(wù)就被稱為分類器。
代碼結(jié)果:

方法如下:
尋找導(dǎo)入的xml文件
import cv2 print(cv2.__file__)
找到cv2安裝的路徑,在該路徑下找到/data文件。

里面默認(rèn)下載了一部分xml文件,不是全部的xml文件。如果需要的xml文件不在里面,需要自行在網(wǎng)上下載,然后放到該目錄下,以備調(diào)用。比如自行安裝('haarcascade_mcs_nose.xml','haarcascade_mcs_mouth.xml')
導(dǎo)入包:
import cv2
導(dǎo)入xml文件,可以根據(jù)任務(wù)需要,自行選擇需要導(dǎo)入的xml文件
#人臉檢測(cè)器 face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml') #眼睛檢測(cè)器 eye_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_eye.xml') #嘴巴檢測(cè)器 mouth_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_mcs_mouth.xml') #鼻子檢測(cè)器 nose_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_mcs_nose.xml')
設(shè)置窗口:
cv2.namedWindow('mytest', 0);
cv2.resizeWindow('mytest', 1500, 1000)打開攝像頭,人臉識(shí)別:
#獲取攝像頭
cap = cv2.VideoCapture(0,cv2.CAP_DSHOW)
#打開攝像頭
cap.open(0)
while cap.isOpened():
#獲取畫面
flag, frame = cap.read()
#人臉檢測(cè)
faces = face_cascade.detectMultiScale(frame, 1.3, 2)
img = frame
for (x, y, w, h) in faces:
#根據(jù)人臉坐標(biāo)和長(zhǎng)度,寬度畫出矩形
img = cv2.rectangle(img, (x, y), (x+w, y+h),(255, 0 ,0), 2)
#確定人臉?lè)秶?,在人臉上搜索其他特?
face_area = img[y:y+h, x:x+w]
#人眼檢測(cè)
eyes = eye_cascade.detectMultiScale(face_area, 1.3, 2)
for (ex, ey, ew, eh) in eyes:
cv2.rectangle(face_area, (ex, ey), (ex + ew, ey + eh), (255, 0 ,0), 1)
#嘴巴檢測(cè)
mouth = mouth_cascade.detectMultiScale(face_area, 1.5, 2)
for (mx, my, mw, mh) in mouth:
cv2.rectangle(face_area, (mx, my), (mx + mw, my + mh), (0, 0, 255), 2)
# 鼻子檢測(cè)
nose = nose_cascade.detectMultiScale(face_area, 1.2, 5)
for (nx, ny, nw, nh) in nose:
cv2.rectangle(face_area, (nx, ny), (nx + nw, ny + nh), (255, 0, 255), 2)
#畫面顯示
cv2.imshow('mytest', img)
#設(shè)置退出按鈕
key_pressed = cv2.waitKey(100)
print('單機(jī)窗口,輸入按鍵,電腦按鍵為',key_pressed,'按esc鍵結(jié)束')
if key_pressed == 27:
break
#關(guān)閉攝像頭
cap.release()
#關(guān)閉圖像窗口
cv2.destroyAllWindows()完整代碼:
import cv2
#人臉檢測(cè)器
face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml')
#眼睛檢測(cè)器
eye_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_eye.xml')
#嘴巴檢測(cè)器
mouth_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_mcs_mouth.xml')
#鼻子檢測(cè)器
nose_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_mcs_nose.xml')
#獲取攝像頭
cap = cv2.VideoCapture(0,cv2.CAP_DSHOW)
#打開攝像頭
cap.open(0)
cv2.namedWindow('mytest', 0);
cv2.resizeWindow('mytest', 1500, 1000)
while cap.isOpened():
#獲取畫面
flag, frame = cap.read()
#人臉檢測(cè)
faces = face_cascade.detectMultiScale(frame, 1.3, 2)
img = frame
for (x, y, w, h) in faces:
#根據(jù)人臉坐標(biāo)和長(zhǎng)度,寬度畫出矩形
img = cv2.rectangle(img, (x, y), (x+w, y+h),(255, 0 ,0), 2)
#確定人臉?lè)秶?,在人臉上搜索其他特?
face_area = img[y:y+h, x:x+w]
#人眼檢測(cè)
eyes = eye_cascade.detectMultiScale(face_area, 1.3, 2)
for (ex, ey, ew, eh) in eyes:
cv2.rectangle(face_area, (ex, ey), (ex + ew, ey + eh), (255, 0 ,0), 1)
#嘴巴檢測(cè)
mouth = mouth_cascade.detectMultiScale(face_area, 1.5, 2)
for (mx, my, mw, mh) in mouth:
cv2.rectangle(face_area, (mx, my), (mx + mw, my + mh), (0, 0, 255), 2)
# 鼻子檢測(cè)
nose = nose_cascade.detectMultiScale(face_area, 1.2, 5)
for (nx, ny, nw, nh) in nose:
cv2.rectangle(face_area, (nx, ny), (nx + nw, ny + nh), (255, 0, 255), 2)
#畫面顯示
cv2.imshow('mytest', img)
#設(shè)置退出按鈕
key_pressed = cv2.waitKey(100)
print('單機(jī)窗口,輸入按鍵,電腦按鍵為',key_pressed,'按esc鍵結(jié)束')
if key_pressed == 27:
break
#關(guān)閉攝像頭
cap.release()
#關(guān)閉圖像窗口
cv2.destroyAllWindows()總結(jié)
到此這篇關(guān)于python實(shí)現(xiàn)人臉檢測(cè)的文章就介紹到這了,更多相關(guān)python人臉檢測(cè)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- python結(jié)合opencv實(shí)現(xiàn)人臉檢測(cè)與跟蹤
- Python+OpenCV人臉檢測(cè)原理及示例詳解
- python中使用OpenCV進(jìn)行人臉檢測(cè)的例子
- Python OpenCV利用筆記本攝像頭實(shí)現(xiàn)人臉檢測(cè)
- Python OpenCV調(diào)用攝像頭檢測(cè)人臉并截圖
- python 基于dlib庫(kù)的人臉檢測(cè)的實(shí)現(xiàn)
- Python基于OpenCV實(shí)現(xiàn)視頻的人臉檢測(cè)
- python opencv人臉檢測(cè)提取及保存方法
- 50行Python代碼實(shí)現(xiàn)人臉檢測(cè)功能
- python利用OpenCV2實(shí)現(xiàn)人臉檢測(cè)
相關(guān)文章
解決jupyter notebook圖片顯示模糊和保存清晰圖片的操作
這篇文章主要介紹了解決jupyter notebook圖片顯示模糊和保存清晰圖片的操作方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-04-04
Python中使用Frozenset對(duì)象的案例詳解
Frozensets提供了一種創(chuàng)建不可變的集合的方法,它們只接受唯一的元素,并且是可散列類型的對(duì)象,所以它們可以在其他只接受可散列對(duì)象作為子對(duì)象的?Python?對(duì)象中使用,這篇文章主要介紹了如何在Python中使用Frozenset對(duì)象,需要的朋友可以參考下2022-08-08
基于python和flask實(shí)現(xiàn)http接口過(guò)程解析
這篇文章主要介紹了基于python和flask實(shí)現(xiàn)http接口過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06
Pytorch 搭建分類回歸神經(jīng)網(wǎng)絡(luò)并用GPU進(jìn)行加速的例子
今天小編就為大家分享一篇Pytorch 搭建分類回歸神經(jīng)網(wǎng)絡(luò)并用GPU進(jìn)行加速的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-01-01
使用python求解迷宮問(wèn)題的三種實(shí)現(xiàn)方法
關(guān)于迷宮問(wèn)題,常見會(huì)問(wèn)能不能到達(dá)某點(diǎn),以及打印到達(dá)的最短路徑,下面這篇文章主要給大家介紹了關(guān)于如何使用python求解迷宮問(wèn)題的三種實(shí)現(xiàn)方法,需要的朋友可以參考下2022-03-03
Django2.1集成xadmin管理后臺(tái)所遇到的錯(cuò)誤集錦(填坑)
這篇文章主要介紹了Django2.1集成xadmin管理后臺(tái)所遇到的錯(cuò)誤集錦(填坑),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12

