黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

Python基于OpenCV實現(xiàn)人臉檢測并保存

系統(tǒng) 2366 0

本文實例為大家分享了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) #將當前楨圖像轉(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
   #將當前幀保存為圖片
   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í)有所幫助,也希望大家多多支持腳本之家。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。。?/p>

發(fā)表我的評論
最新評論 總共0條評論