Python基于OpenCV實現(xiàn)人臉檢測并保存
本文實例為大家分享了Python基于OpenCV實現(xiàn)人臉檢測,并保存的具體代碼,供大家參考,具體內(nèi)容如下
安裝opencv
如果安裝了pip的話,Opencv的在windows的安裝可以直接通過cmd命令pip install opencv-python(只需要主要模塊),也可以輸入命令pip install opencv-contrib-python(如果需要main模塊和contrib模塊)
詳情可以點擊此處
導(dǎo)入opencv
import cv2
所有包都包含haarcascade文件。這個文件很重要!!!
cv2.data.haarcascades可以用作數(shù)據(jù)文件夾的快捷方式。例如:
cv2.CascadeClassifier(cv2.data.haarcascades + "haarcascade_frontalface_default.xml")
代碼
#-*- coding: utf-8 -*-
# import openCV的庫
import cv2
import os, math, operator
from PIL import Image
from functools import reduce
###調(diào)用電腦攝像頭檢測人臉并截圖
def CatchPICFromVideo(window_name, path_name):
cv2.namedWindow(window_name)
#電腦攝像頭
cap = cv2.VideoCapture(0)
#告訴OpenCV使用人臉識別分類器
classfier = cv2.CascadeClassifier(cv2.data.haarcascades + "haarcascade_frontalface_default.xml")
#檢測人臉后要畫的邊框的顏色
color = (0, 255, 0)
while cap.isOpened():
ok, frame = cap.read() #讀取一幀數(shù)據(jù)
if not ok:
break
grey = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) #將當(dāng)前楨圖像轉(zhuǎn)換成灰度圖像
#人臉檢測,1.2和2分別為圖片縮放比例和需要檢測的有效點數(shù)
faceRects = classfier.detectMultiScale(grey, scaleFactor = 1.2, minNeighbors = 3, minSize = (32, 32))
if len(faceRects) > 0: #大于0則檢測到人臉
for faceRect in faceRects: #單獨框出每一張人臉
x, y, w, h = faceRect
#畫出矩形框
cv2.rectangle(frame, (x - 10, y - 10), (x + w + 10, y + h + 10), color, 2)
k = cv2.waitKey(100) #每0.1秒讀一次鍵盤
if k == ord("z") or k == ord("Z"): #如果輸入z
#將當(dāng)前幀保存為圖片
img_name = path_name
print(img_name)
image = frame[y - 10: y + h + 10, x - 10: x + w + 10]
cv2.imwrite(img_name, image,[int(cv2.IMWRITE_PNG_COMPRESSION), 9])
break
#顯示圖像
cv2.imshow(window_name, frame)
#退出攝像頭界面
c = cv2.waitKey(100)
if c == ord("q") or c == ord("Q"):
break
#釋放攝像頭并銷毀所有窗口
cap.release()
cv2.destroyAllWindows()
os.system("cls") #清屏
recogname = "recogface.jpg" #預(yù)存的人臉文件
CatchPICFromVideo("get face",recogname)
功能:
雖然能框住人臉,但是效率還不是很高。
按Z或z可以將框住的人臉截取保存
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
多個geojson經(jīng)過坐標(biāo)系轉(zhuǎn)換后如何合并為一個shp數(shù)據(jù)
這篇文章主要介紹了多個geojson經(jīng)過坐標(biāo)系轉(zhuǎn)換后如何合并為一個shp數(shù)據(jù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10
出現(xiàn)module 'queue' has no attrib
這篇文章主要介紹了出現(xiàn)module 'queue' has no attribute 'Queue'問題的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04
Python 合并多個TXT文件并統(tǒng)計詞頻的實現(xiàn)
這篇文章主要介紹了Python 合并多個TXT文件并統(tǒng)計詞頻的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
python實現(xiàn)根據(jù)用戶輸入從電影網(wǎng)站獲取影片信息的方法
這篇文章主要介紹了python實現(xiàn)根據(jù)用戶輸入從電影網(wǎng)站獲取影片信息的方法,涉及Python正則表達(dá)式抓取網(wǎng)頁的技巧,非常具有實用價值,需要的朋友可以參考下2015-04-04
使用Python自制數(shù)據(jù)庫備份工具實現(xiàn)數(shù)據(jù)定時覆蓋
這篇文章主要為大家詳細(xì)介紹了如何使用Python自制數(shù)據(jù)庫備份工具實現(xiàn)數(shù)據(jù)定時覆蓋功能,文中的示例代碼講解詳細(xì),需要的小伙伴可以參考下2024-03-03
python?plotly設(shè)置go.Scatter為實線實例
這篇文章主要為大家介紹了python?plotly設(shè)置go.Scatter為實線線條的樣式實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10
python解釋器pycharm安裝及環(huán)境變量配置教程圖文詳解
這篇文章主要介紹了python解釋器pycharm安裝及環(huán)境變量配置教程圖文詳解,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2020-02-02
pycharm配置安裝autopep8自動規(guī)范代碼的實現(xiàn)
這篇文章主要介紹了pycharm配置安裝autopep8自動規(guī)范代碼的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
python3中超級好用的日志模塊-loguru模塊使用詳解
loguru默認(rèn)的輸出格式是上面的內(nèi)容,有時間、級別、模塊名、行號以及日志信息,不需要手動創(chuàng)建?logger,直接使用即可,另外其輸出還是彩色的,看起來會更加友好,這篇文章主要介紹了python3中超級好用的日志模塊-loguru模塊使用詳解,需要的朋友可以參考下2022-11-11

