Python學(xué)習(xí)筆記之圖片人臉檢測(cè)識(shí)別實(shí)例教程
前言
隨著科技的發(fā)展,人臉識(shí)別技術(shù)在許多領(lǐng)域得到的非常廣泛的應(yīng)用,手機(jī)支付、銀行身份驗(yàn)證、手機(jī)人臉解鎖等等。
識(shí)別
廢話少說(shuō),這里我們使用 opencv 中自帶了 haar人臉特征分類器,利用訓(xùn)練好的 haar 特征的 xml 文件,在圖片上檢測(cè)出人臉的坐標(biāo),利用這個(gè)坐標(biāo),我們可以將人臉區(qū)域剪切保存,也可以在原圖上將人臉框出。
代碼實(shí)現(xiàn):
# -*-coding:utf8-*-#
import os
import cv2
from PIL import Image, ImageDraw
from datetime import datetime
"""
分類器 https://github.com/opencv/opencv/tree/master/data/haarcascades
安裝模塊:pip install Pillow pip install opencv-python
博客:https://blog.52itstyle.vip/archives/3771/
"""
def detectFaces(image_name):
img = cv2.imread(image_name)
face_cascade = cv2.CascadeClassifier(os.getcwd()+"\\haarcascade\\haarcascade_frontalface_alt.xml")
if img.ndim == 3:
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
else:
gray = img # if語(yǔ)句:如果img維度為3,說(shuō)明不是灰度圖,先轉(zhuǎn)化為灰度圖gray,如果不為3,也就是2,原圖就是灰度圖
faces = face_cascade.detectMultiScale(gray, 1.2, 5) # 1.3和5是特征的最小、最大檢測(cè)窗口,它改變檢測(cè)結(jié)果也會(huì)改變
result = []
for (x, y, width, height) in faces:
result.append((x, y, x + width, y + height))
return result
# 保存人臉圖
def saveFaces(image_name):
faces = detectFaces(image_name)
if faces:
# 將人臉保存在save_dir目錄下。
# Image模塊:Image.open獲取圖像句柄,crop剪切圖像(剪切的區(qū)域就是detectFaces返回的坐標(biāo)),save保存。
save_dir = image_name.split('.')[0] + "_faces"
os.mkdir(save_dir)
count = 0
for (x1, y1, x2, y2) in faces:
file_name = os.path.join(save_dir, str(count) + ".jpg")
Image.open(image_name).crop((x1, y1, x2, y2)).save(file_name)
count += 1
if __name__ == '__main__':
time1 = datetime.now()
result = detectFaces(os.getcwd()+"\\images\\gaoyuanyuan.jpg")
time2 = datetime.now()
print("耗時(shí):" + str(time2 - time1))
if len(result) > 0:
print("有人存在??!---》人數(shù)為:" + str(len(result)))
else:
print('視頻圖像中無(wú)人??!')
drawFaces(os.getcwd()+"\\images\\", "hanxue.jpg")
saveFaces(os.getcwd()+\\images\\gaoyuanyuan.jpg)
識(shí)別效果圖:

多人識(shí)別效果:

經(jīng)過(guò)測(cè)試,最終選用了 haarcascade_frontalface_alt.xml 做人臉識(shí)別,識(shí)別率最高。
人臉檢測(cè)分類器對(duì)比:
| 級(jí)聯(lián)分類器的類型 | XML文件名 |
|---|---|
| 人臉檢測(cè)器(默認(rèn)) | haarcascade_frontalface_default.xml |
| 人臉檢測(cè)器(快速的Haar) | haarcascade_frontalface_alt2.xml |
| 人臉檢測(cè)器(Tree) | haarcascade_frontalface_alt_tree.xml |
| 人臉檢測(cè)器(Haar_1) | haarcascade_frontalface_alt.xml |
小結(jié)
開源的人臉檢測(cè)分類器對(duì)于標(biāo)準(zhǔn)的人臉識(shí)別足夠了,要想精確識(shí)別比如,側(cè)臉、模糊、光照、遮擋的人臉,只能通過(guò)深度機(jī)器學(xué)習(xí)進(jìn)一步優(yōu)化識(shí)別精度和速度。
源碼
https://gitee.com/52itstyle/Python/tree/master/Day09(本地下載)
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
- python實(shí)現(xiàn)圖像檢索的三種(直方圖/OpenCV/哈希法)
- Python Opencv任意形狀目標(biāo)檢測(cè)并繪制框圖
- opencv python 圖像輪廓/檢測(cè)輪廓/繪制輪廓的方法
- python opencv實(shí)現(xiàn)圖像邊緣檢測(cè)
- Python基于matplotlib畫箱體圖檢驗(yàn)異常值操作示例【附xls數(shù)據(jù)文件下載】
- python用10行代碼實(shí)現(xiàn)對(duì)黃色圖片的檢測(cè)功能
- 用Python實(shí)現(xiàn)通過(guò)哈希算法檢測(cè)圖片重復(fù)的教程
- Python檢查圖片是否損壞及圖片類型是否正確過(guò)程詳解
相關(guān)文章
Python+pandas編寫命令行腳本操作excel的tips詳情
這篇文章主要介紹了Python+pandas編寫命令行腳本操作excel的tips詳情,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-07-07
python文件讀寫并使用mysql批量插入示例分享(python操作mysql)
這篇文章主要介紹了python文件讀寫并使用mysql批量插入示例,可以學(xué)習(xí)到python操作mysql數(shù)據(jù)庫(kù)的方法,需要的朋友可以參考下2014-02-02
Python調(diào)用百度AI實(shí)現(xiàn)人像分割詳解
本文主要介紹了如何通過(guò)Python調(diào)用百度AI從而實(shí)現(xiàn)人像的分割與合成,文中的示例代碼對(duì)我們的工作或?qū)W習(xí)有一定的幫助,需要的朋友可以參考一下2021-12-12
Keras自定義實(shí)現(xiàn)帶masking的meanpooling層方式
這篇文章主要介紹了Keras自定義實(shí)現(xiàn)帶masking的meanpooling層方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-06-06
Python解決ModuleNotFoundError: No module named&
ModuleNotFoundError: No module named 'PIL'是一個(gè)常見的Python錯(cuò)誤,通常出現(xiàn)在使用Pillow庫(kù)時(shí),Pillow是Python中用于圖像處理的一個(gè)庫(kù),其前身是PIL,本文介紹了Python解決ModuleNotFoundError: No module named 'PIL'的問(wèn)題,需要的朋友可以參考下2024-09-09
關(guān)于windos10環(huán)境下編譯python3版pjsua庫(kù)的問(wèn)題
pjsua默認(rèn)綁定的python版本是python 2.4,使用起來(lái)有諸多限制,希望可以使用python3調(diào)用pjsua的庫(kù)實(shí)現(xiàn)軟電話的基礎(chǔ)功能。這篇文章主要介紹了windos10環(huán)境下編譯python3版pjsua庫(kù),需要的朋友可以參考下2021-10-10
Python 基于FIR實(shí)現(xiàn)Hilbert濾波器求信號(hào)包絡(luò)詳解
今天小編就為大家分享一篇Python 基于FIR實(shí)現(xiàn)Hilbert濾波器求信號(hào)包絡(luò)詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-02-02

