Python基于OpenCV實(shí)現(xiàn)人臉檢測并保存
本文實(shí)例為大家分享了Python基于OpenCV實(shí)現(xiàn)人臉檢測,并保存的具體代碼,供大家參考,具體內(nèi)容如下
安裝opencv
如果安裝了pip的話,Opencv的在windows的安裝可以直接通過cmd命令pip install opencv-python(只需要主要模塊),也可以輸入命令pip install opencv-contrib-python(如果需要main模塊和contrib模塊)
詳情可以點(diǎn)擊此處
導(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分別為圖片縮放比例和需要檢測的有效點(diǎn)數(shù) faceRects = classfier.detectMultiScale(grey, scaleFactor = 1.2, minNeighbors = 3, minSize = (32, 32)) if len(faceRects) > 0: #大于0則檢測到人臉 for faceRect in faceRects: #單獨(dú)框出每一張人臉 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í)有所幫助,也希望大家多多支持腳本之家。
- python結(jié)合opencv實(shí)現(xiàn)人臉檢測與跟蹤
- Python+OpenCV人臉檢測原理及示例詳解
- python中使用OpenCV進(jìn)行人臉檢測的例子
- Python OpenCV利用筆記本攝像頭實(shí)現(xiàn)人臉檢測
- Python基于OpenCV實(shí)現(xiàn)視頻的人臉檢測
- Python OpenCV調(diào)用攝像頭檢測人臉并截圖
- OpenCV-Python 攝像頭實(shí)時檢測人臉代碼實(shí)例
- python版opencv攝像頭人臉實(shí)時檢測方法
- OpenCV實(shí)現(xiàn)人臉檢測
- opencv基于Haar人臉檢測和眼睛檢測
相關(guān)文章
python向xls寫入數(shù)據(jù)(包括合并,邊框,對齊,列寬)
這篇文章主要介紹了python向xls寫入數(shù)據(jù)(包括合并,邊框,對齊,列寬),幫助大家更好的利用python處理表格,感興趣的朋友可以了解下2021-02-02python3.6.3安裝圖文教程 TensorFlow安裝配置方法
這篇文章主要為大家詳細(xì)介紹了python3.6.3及TensorFlow安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-09Django 實(shí)現(xiàn) Websocket 廣播、點(diǎn)對點(diǎn)發(fā)送消息的代碼
這篇文章主要介紹了Django 實(shí)現(xiàn) Websocket 廣播、點(diǎn)對點(diǎn)發(fā)送消息,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06Python中np.percentile和df.quantile分位數(shù)詳解
分位數(shù)(Quantile)亦稱分位點(diǎn)是指將一個隨機(jī)變量的概率分布范圍分為幾個等份的數(shù)值點(diǎn),下面這篇文章主要給大家介紹了關(guān)于Python中np.percentile和df.quantile分位數(shù)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05使用Python?Cupy模塊加速大規(guī)模數(shù)值計算實(shí)例深究
Cupy是一個基于NumPy的庫,專門設(shè)計用于在GPU上進(jìn)行高性能計算,它提供了與NumPy相似的API,因此用戶可以很容易地將現(xiàn)有的NumPy代碼遷移到Cupy上,從而充分利用GPU的并行計算能力2023-12-12