欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python實現(xiàn)人臉檢測的簡單實例

 更新時間:2022年02月22日 16:15:45   作者:wh來啦  
這篇文章主要給大家介紹了關(guān)于python實現(xiàn)人臉檢測的相關(guān)資料,OpenCV?可以使用機器學(xué)習(xí)算法搜索圖像中的人臉,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

OpenCV

OpenCV 是計算機視覺領(lǐng)域最受歡迎的開源庫,起初它由 C/C ++ 編寫,現(xiàn)在用 Python 也能使用。

OpenCV 可以使用機器學(xué)習(xí)算法搜索圖像中的人臉。由于人臉比較復(fù)雜,所以并沒有一種簡單的測試可以告訴我們它是否發(fā)現(xiàn)了人臉。但是,算法能夠匹配到數(shù)千個很小的模式和特征。算法會將識別人臉的任務(wù)分解為幾千個非常非常小的任務(wù),像這種很小的任務(wù),解決起來就比較容易了。這樣的微小任務(wù)就被稱為分類器。

代碼結(jié)果:

方法如下:

尋找導(dǎo)入的xml文件

import cv2 
print(cv2.__file__)

找到cv2安裝的路徑,在該路徑下找到/data文件。

里面默認下載了一部分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文件

#人臉檢測器
face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml')
#眼睛檢測器
eye_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_eye.xml')
#嘴巴檢測器
mouth_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_mcs_mouth.xml')
#鼻子檢測器
nose_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_mcs_nose.xml')

 設(shè)置窗口:

cv2.namedWindow('mytest', 0);
cv2.resizeWindow('mytest', 1500, 1000)

 打開攝像頭,人臉識別:

#獲取攝像頭
cap = cv2.VideoCapture(0,cv2.CAP_DSHOW)
#打開攝像頭
cap.open(0)
while cap.isOpened():
    #獲取畫面
    flag, frame = cap.read()
 
    #人臉檢測
    faces = face_cascade.detectMultiScale(frame, 1.3, 2)
    img = frame
    for (x, y, w, h) in faces:
        #根據(jù)人臉坐標(biāo)和長度,寬度畫出矩形
        img = cv2.rectangle(img, (x, y), (x+w, y+h),(255, 0 ,0), 2)
        
        #確定人臉范圍,在人臉上搜索其他特征
        face_area = img[y:y+h, x:x+w]
        
        #人眼檢測
        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)
 
        #嘴巴檢測
        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)
 
        # 鼻子檢測
        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('單機窗口,輸入按鍵,電腦按鍵為',key_pressed,'按esc鍵結(jié)束')
    if key_pressed == 27:
        break
 
#關(guān)閉攝像頭
cap.release()
#關(guān)閉圖像窗口
cv2.destroyAllWindows()

完整代碼:

import cv2
#人臉檢測器
face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml')
#眼睛檢測器
eye_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_eye.xml')
#嘴巴檢測器
mouth_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_mcs_mouth.xml')
#鼻子檢測器
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()
 
    #人臉檢測
    faces = face_cascade.detectMultiScale(frame, 1.3, 2)
    img = frame
    for (x, y, w, h) in faces:
        #根據(jù)人臉坐標(biāo)和長度,寬度畫出矩形
        img = cv2.rectangle(img, (x, y), (x+w, y+h),(255, 0 ,0), 2)
 
        #確定人臉范圍,在人臉上搜索其他特征
        face_area = img[y:y+h, x:x+w]
 
        #人眼檢測
        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)
 
        #嘴巴檢測
        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)
 
        # 鼻子檢測
        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('單機窗口,輸入按鍵,電腦按鍵為',key_pressed,'按esc鍵結(jié)束')
    if key_pressed == 27:
        break
 
#關(guān)閉攝像頭
cap.release()
#關(guān)閉圖像窗口
cv2.destroyAllWindows()

總結(jié)

到此這篇關(guān)于python實現(xiàn)人臉檢測的文章就介紹到這了,更多相關(guān)python人臉檢測內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python設(shè)置代理和添加鏡像源的方法

    python設(shè)置代理和添加鏡像源的方法

    這篇文章主要介紹了python設(shè)置代理和添加鏡像源介紹,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • 解決jupyter notebook圖片顯示模糊和保存清晰圖片的操作

    解決jupyter notebook圖片顯示模糊和保存清晰圖片的操作

    這篇文章主要介紹了解決jupyter notebook圖片顯示模糊和保存清晰圖片的操作方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • Python必備技巧之字符數(shù)據(jù)操作詳解

    Python必備技巧之字符數(shù)據(jù)操作詳解

    處理字符數(shù)據(jù)是編程不可或缺的一部分。Python?提供了一組豐富的運算符、函數(shù)和方法來處理字符串。包括字符串運算符、內(nèi)置函數(shù)、索引、切片和內(nèi)置方法??靵韺W(xué)習(xí)一下吧
    2022-03-03
  • Python中使用Frozenset對象的案例詳解

    Python中使用Frozenset對象的案例詳解

    Frozensets提供了一種創(chuàng)建不可變的集合的方法,它們只接受唯一的元素,并且是可散列類型的對象,所以它們可以在其他只接受可散列對象作為子對象的?Python?對象中使用,這篇文章主要介紹了如何在Python中使用Frozenset對象,需要的朋友可以參考下
    2022-08-08
  • 基于python和flask實現(xiàn)http接口過程解析

    基于python和flask實現(xiàn)http接口過程解析

    這篇文章主要介紹了基于python和flask實現(xiàn)http接口過程解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-06-06
  • Python中tqdm的使用和例子

    Python中tqdm的使用和例子

    Tqdm是一個快速,可擴展的Python進度條,可以在 Python 長循環(huán)中添加一個進度提示信息,用戶只需要封裝任意的迭代器tqdm(iterator),下面這篇文章主要給大家介紹了關(guān)于Python中tqdm的使用和例子的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • Pytorch 搭建分類回歸神經(jīng)網(wǎng)絡(luò)并用GPU進行加速的例子

    Pytorch 搭建分類回歸神經(jīng)網(wǎng)絡(luò)并用GPU進行加速的例子

    今天小編就為大家分享一篇Pytorch 搭建分類回歸神經(jīng)網(wǎng)絡(luò)并用GPU進行加速的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • Python魔術(shù)方法詳解

    Python魔術(shù)方法詳解

    這篇文章主要介紹了Python魔術(shù)方法詳解,本文講解了構(gòu)造和初始化、用于比較的魔術(shù)方法、數(shù)值處理的魔術(shù)方法、普通算數(shù)操作符等內(nèi)容,需要的朋友可以參考下
    2015-02-02
  • 使用python求解迷宮問題的三種實現(xiàn)方法

    使用python求解迷宮問題的三種實現(xiàn)方法

    關(guān)于迷宮問題,常見會問能不能到達某點,以及打印到達的最短路徑,下面這篇文章主要給大家介紹了關(guān)于如何使用python求解迷宮問題的三種實現(xiàn)方法,需要的朋友可以參考下
    2022-03-03
  • Django2.1集成xadmin管理后臺所遇到的錯誤集錦(填坑)

    Django2.1集成xadmin管理后臺所遇到的錯誤集錦(填坑)

    這篇文章主要介紹了Django2.1集成xadmin管理后臺所遇到的錯誤集錦(填坑),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12

最新評論