婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 基于python3+OpenCV實現人臉和眼睛識別

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

熱門標簽:怎么辦理400客服電話 沈陽防封電銷電話卡 企業微信地圖標注 高德地圖標注收入咋樣 地圖標注多個 B52系統電梯外呼顯示E7 鶴壁手機自動外呼系統違法嗎 萊蕪電信外呼系統 銀川電話機器人電話

基于python3+OpenCV的人臉和眼睛識別,供大家參考,具體內容如下

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

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

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

2、點擊Raw:

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)

我們用到的原圖如下:

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

利用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)

識別的效果如下:

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

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

# 在人臉的基礎上識別眼睛
    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)

效果如下:

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • python實現圖片,視頻人臉識別(opencv版)
  • Python基于Opencv來快速實現人臉識別過程詳解(完整版)
  • Python opencv實現人眼/人臉識別以及實時打碼處理
  • Python基于OpenCV庫Adaboost實現人臉識別功能詳解
  • python調用OpenCV實現人臉識別功能
  • python opencv3實現人臉識別(windows)
  • 基于python3 OpenCV3實現靜態圖片人臉識別
  • python+opencv實現的簡單人臉識別代碼示例
  • 詳解如何用OpenCV + Python 實現人臉識別
  • python使用opencv進行人臉識別

標簽:呼倫貝爾 烏魯木齊 呼倫貝爾 安慶 葫蘆島 銀川 三亞 湘西

巨人網絡通訊聲明:本文標題《基于python3+OpenCV實現人臉和眼睛識別》,本文關鍵詞  基于,python3+OpenCV,實現,人臉,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《基于python3+OpenCV實現人臉和眼睛識別》相關的同類信息!
  • 本頁收集關于基于python3+OpenCV實現人臉和眼睛識別的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 禹城市| 武强县| 松滋市| 高雄县| 临桂县| 洮南市| 建水县| 年辖:市辖区| 广东省| 馆陶县| 大理市| 民和| 岳池县| 黄大仙区| 平凉市| 贵港市| 咸阳市| 公主岭市| 汽车| 遂川县| 三原县| 西藏| 如皋市| 黄陵县| 阿克| 灵武市| 封丘县| 庆安县| 湘西| 兰溪市| 莫力| 枣阳市| 富源县| 大余县| 宁陕县| 通海县| 大同市| 藁城市| 芜湖县| 岳普湖县| 钟祥市|