中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

基于python3+OpenCV如何實現人臉和眼睛識別

發布時間:2021-09-06 13:48:39 來源:億速云 閱讀:135 作者:小新 欄目:開發技術

這篇文章主要介紹了基于python3+OpenCV如何實現人臉和眼睛識別,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

一、OpenCV人臉檢測的xml文件下載

人臉檢測和眼睛檢測要用到haarcascade_eye.xml和haarcascade_frontalface_default.xml這兩個文件,這兩個文件可以在OpenCV的官網下載,具體下載方法如下:

1、打開要下載的xml文件,如下圖:

基于python3+OpenCV如何實現人臉和眼睛識別

2、點擊Raw:

基于python3+OpenCV如何實現人臉和眼睛識別

3、在新打開的網頁中右擊,選擇另存為,最后保存就可以了。

二、人臉檢測文件的導入以及圖片的處理

接下來就可以在代碼中載入剛才下載的兩個xml文件,再將要識別的圖片進行灰度處理了,代碼如下:

import cv2
# 載入人臉識別和眼睛識別的兩個xml文件
face_xml = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
eye_xml = cv2.CascadeClassifier('haarcascade_eye.xml')
# 載入圖片
img = cv2.imread('face.jpg')
cv2.imshow('src', img)
# 灰度處理
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

我們用到的原圖如下:

基于python3+OpenCV如何實現人臉和眼睛識別

三、人臉識別并用方框顯示人臉位置

利用face_xml.detectMultiScale()方法識別出人臉的位置,并利用cv2.rectangle()繪制方框,具體代碼如下:

# 人臉識別
face = face_xml.detectMultiScale(gray, 1.3, 2)  # 參數:1、灰度圖片, 2、縮放比例, 3、閾值
print("這張圖片中有%d張人臉" % len(face))
# 繪制出識別到的人臉
for (x, y, w, h) in face:
    cv2.rectangle(img, (x, y), (x+w, y+h), (0, 255, 0), 2)  # 繪制人臉方框
    cv2.imshow('dst', img)
    cv2.waitkey(0)

識別的效果如下:

基于python3+OpenCV如何實現人臉和眼睛識別

四、眼睛識別并用方框顯示眼睛位置

和人臉識別類似,不過眼睛識別是在人臉識別的基礎上再進行識別的,所以將人臉的圖片進行灰度化處理,再識別,代碼如下:

# 在人臉的基礎上識別眼睛
    face_gray = gray[y:y+h, x:x+w]
    face_color = img[y:y+h, x:x+w]
    # 眼睛識別
    eyes = eye_xml.detectMultiScale(face_gray)
    print("在這張臉上有%d個眼睛" % len(eyes))
    # 繪制出識別到的眼睛
    for (e_x, e_y, e_w, e_h) in eyes:
        cv2.rectangle(face_color, (e_x, e_y), (e_x+e_w, e_y+e_h), (0, 255, 0), 2)  # 繪制眼睛方框

五、源碼及效果

源碼如下:

# -*- coding: utf-8 -*-
"""
-------------------------------------------------
   File Name:     03-face.py
   Description :  基于OpenCV的人臉和眼睛識別
   Author :      小戀莫小哀
   Email:      xiaowen0392@qq.com
   date:          2019/6/2
-------------------------------------------------
   Change Activity:
                   2019/6/2:
-------------------------------------------------
"""
__author__ = 'WWQ'

import cv2
# 載入人臉識別和眼睛識別的兩個xml文件
face_xml = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
eye_xml = cv2.CascadeClassifier('haarcascade_eye.xml')
# 載入圖片
img = cv2.imread('face.jpg')
cv2.imshow('src', img)
# 灰度處理
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# 人臉識別
face = face_xml.detectMultiScale(gray, 1.3, 2)  # 參數:1、灰度圖片, 2、縮放比例, 3、閾值
print("這張圖片中有%d張人臉" % len(face))
# 繪制出識別到的人臉
for (x, y, w, h) in face:
    cv2.rectangle(img, (x, y), (x+w, y+h), (0, 255, 0), 2)  # 繪制人臉方框
    # cv2.imshow('dst', img)
    # 在人臉的基礎上識別眼睛
    face_gray = gray[y:y+h, x:x+w]
    face_color = img[y:y+h, x:x+w]
    # 眼睛識別
    eyes = eye_xml.detectMultiScale(face_gray)
    print("在這張臉上有%d個眼睛" % len(eyes))
    # 繪制出識別到的眼睛
    for (e_x, e_y, e_w, e_h) in eyes:
        cv2.rectangle(face_color, (e_x, e_y), (e_x+e_w, e_y+e_h), (0, 255, 0), 2)  # 繪制眼睛方框
cv2.imshow('dst', img)
cv2.waitKey(0)

效果如下:

基于python3+OpenCV如何實現人臉和眼睛識別

感謝你能夠認真閱讀完這篇文章,希望小編分享的“基于python3+OpenCV如何實現人臉和眼睛識別”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巩义市| 达州市| 河北区| 瑞昌市| 兴文县| 乐平市| 泰顺县| 伊金霍洛旗| 蒲城县| 淮阳县| 和林格尔县| 古浪县| 龙川县| 怀仁县| 诸城市| 新疆| 沾化县| 吉林市| 临沂市| 林周县| 林甸县| 莱西市| 通许县| 兴宁市| 双牌县| 孟州市| 玉林市| 婺源县| 台州市| 奉化市| 宜黄县| 大厂| 监利县| 哈尔滨市| 广灵县| 岳池县| 蒙阴县| 长宁县| 永新县| 商洛市| 浮山县|