python实现人脸检测的简单实例

作者:wh来啦 时间:2023-02-17 16:08:20 

OpenCV

OpenCV 是计算机视觉领域最受欢迎的开源库,起初它由 C/C ++ 编写,现在用 Python 也能使用。

OpenCV 可以使用机器学习算法搜索图像中的人脸。由于人脸比较复杂,所以并没有一种简单的测试可以告诉我们它是否发现了人脸。但是,算法能够匹配到数千个很小的模式和特征。算法会将识别人脸的任务分解为几千个非常非常小的任务,像这种很小的任务,解决起来就比较容易了。这样的微小任务就被称为分类器。

代码结果:

python实现人脸检测的简单实例

方法如下:

寻找导入的xml文件

import cv2
print(cv2.__file__)

找到cv2安装的路径,在该路径下找到/data文件。

python实现人脸检测的简单实例

里面默认下载了一部分xml文件,不是全部的xml文件。如果需要的xml文件不在里面,需要自行在网上下载,然后放到该目录下,以备调用。比如自行安装('haarcascade_mcs_nose.xml','haarcascade_mcs_mouth.xml')

导入包:

import cv2

 导入xml文件,可以根据任务需要,自行选择需要导入的xml文件

#人脸检测器
face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml')
#眼睛检测器
eye_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_eye.xml')
#嘴巴检测器
mouth_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_mcs_mouth.xml')
#鼻子检测器
nose_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_mcs_nose.xml')

 设置窗口:

cv2.namedWindow('mytest', 0);
cv2.resizeWindow('mytest', 1500, 1000)

 打开摄像头,人脸识别:

#获取摄像头
cap = cv2.VideoCapture(0,cv2.CAP_DSHOW)
#打开摄像头
cap.open(0)
while cap.isOpened():
   #获取画面
   flag, frame = cap.read()

#人脸检测
   faces = face_cascade.detectMultiScale(frame, 1.3, 2)
   img = frame
   for (x, y, w, h) in faces:
       #根据人脸坐标和长度,宽度画出矩形
       img = cv2.rectangle(img, (x, y), (x+w, y+h),(255, 0 ,0), 2)

#确定人脸范围,在人脸上搜索其他特征
       face_area = img[y:y+h, x:x+w]

#人眼检测
       eyes = eye_cascade.detectMultiScale(face_area, 1.3, 2)
       for (ex, ey, ew, eh) in eyes:
            cv2.rectangle(face_area, (ex, ey), (ex + ew, ey + eh), (255, 0 ,0), 1)

#嘴巴检测
       mouth = mouth_cascade.detectMultiScale(face_area, 1.5, 2)
       for (mx, my, mw, mh) in mouth:
           cv2.rectangle(face_area, (mx, my), (mx + mw, my + mh), (0, 0, 255), 2)

# 鼻子检测
       nose = nose_cascade.detectMultiScale(face_area, 1.2, 5)
       for (nx, ny, nw, nh) in nose:
           cv2.rectangle(face_area, (nx, ny), (nx + nw, ny + nh), (255, 0, 255), 2)

#画面显示
   cv2.imshow('mytest', img)
   #设置退出按钮
   key_pressed = cv2.waitKey(100)
   print('单机窗口,输入按键,电脑按键为',key_pressed,'按esc键结束')
   if key_pressed == 27:
       break

#关闭摄像头
cap.release()
#关闭图像窗口
cv2.destroyAllWindows()

完整代码:

import cv2
#人脸检测器
face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml')
#眼睛检测器
eye_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_eye.xml')
#嘴巴检测器
mouth_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_mcs_mouth.xml')
#鼻子检测器
nose_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_mcs_nose.xml')

#获取摄像头
cap = cv2.VideoCapture(0,cv2.CAP_DSHOW)
#打开摄像头
cap.open(0)
cv2.namedWindow('mytest', 0);
cv2.resizeWindow('mytest', 1500, 1000)
while cap.isOpened():
   #获取画面
   flag, frame = cap.read()

#人脸检测
   faces = face_cascade.detectMultiScale(frame, 1.3, 2)
   img = frame
   for (x, y, w, h) in faces:
       #根据人脸坐标和长度,宽度画出矩形
       img = cv2.rectangle(img, (x, y), (x+w, y+h),(255, 0 ,0), 2)

#确定人脸范围,在人脸上搜索其他特征
       face_area = img[y:y+h, x:x+w]

#人眼检测
       eyes = eye_cascade.detectMultiScale(face_area, 1.3, 2)
       for (ex, ey, ew, eh) in eyes:
            cv2.rectangle(face_area, (ex, ey), (ex + ew, ey + eh), (255, 0 ,0), 1)

#嘴巴检测
       mouth = mouth_cascade.detectMultiScale(face_area, 1.5, 2)
       for (mx, my, mw, mh) in mouth:
           cv2.rectangle(face_area, (mx, my), (mx + mw, my + mh), (0, 0, 255), 2)

# 鼻子检测
       nose = nose_cascade.detectMultiScale(face_area, 1.2, 5)
       for (nx, ny, nw, nh) in nose:
           cv2.rectangle(face_area, (nx, ny), (nx + nw, ny + nh), (255, 0, 255), 2)

#画面显示
   cv2.imshow('mytest', img)
   #设置退出按钮
   key_pressed = cv2.waitKey(100)
   print('单机窗口,输入按键,电脑按键为',key_pressed,'按esc键结束')
   if key_pressed == 27:
       break

#关闭摄像头
cap.release()
#关闭图像窗口
cv2.destroyAllWindows()

来源:https://blog.csdn.net/qq_52200688/article/details/122712361

标签:python,人脸,检测
0
投稿

猜你喜欢

  • Python中的进程操作模块(multiprocess.process)

    2022-09-17 23:10:32
  • python多进程下的生产者和消费者模型

    2022-05-30 02:37:07
  • KnockoutJS 3.X API 第四章之表单submit、enable、disable绑定

    2023-08-13 03:12:44
  • python正则表达式之对号入座篇

    2021-03-31 17:59:55
  • 如何使用FSO修改文件夹的名称

    2008-10-11 14:24:00
  • 用私有属性来拯救IE7缩放图片的失真

    2009-03-03 13:57:00
  • 对python中基于tcp协议的通信(数据传输)实例讲解

    2023-04-18 14:36:10
  • Python 利用argparse模块实现脚本命令行参数解析

    2022-12-01 16:11:55
  • SQL提取数据库表名及字段名等信息代码示例

    2024-01-26 23:18:54
  • Python查询缺失值的4种方法总结

    2023-10-29 13:42:08
  • pycharm实现设置自动的参数注释标识

    2023-11-25 10:26:23
  • InnoDB的关键特性-插入缓存,两次写,自适应hash索引详解

    2024-01-18 01:28:23
  • 解决mysql安装时出现error Nr.1045问题的方法

    2024-01-18 11:34:30
  • 简述Python中的面向对象编程的概念

    2021-11-08 07:53:11
  • PPOCRLabel标注的txt格式如何转换成labelme能修改的json格式

    2021-08-31 06:01:45
  • Python字节单位转换实例

    2023-07-18 07:09:16
  • Python实现对字典分别按键(key)和值(value)进行排序的方法分析

    2021-06-05 00:36:32
  • MySQL中USING 和 HAVING 用法实例简析

    2024-01-14 22:07:47
  • JS中==与===操作符的比较

    2024-04-17 10:10:23
  • 如何利用Anaconda配置简单的Python环境

    2023-05-05 22:48:54
  • asp之家 网络编程 m.aspxhome.com