使用 Python 和 OpenCV 实现实时人脸识别功能

 更新时间:2024年11月06日 14:15:13   作者:燕鹏01  
本文详细讲解了使用Python和OpenCV库实行实时人脸识别的过程,首先,确保安装OpenCV库,并通过Haar级联分类器进行人脸检测,实现步骤包括打开摄像头、图像灰度转换、人脸检测及绘制矩形框,代码示例清晰展示了从设置摄像头到最终展示检测结果的完整过程

概述

人脸识别是一项重要的计算机视觉任务,广泛应用于安全监控、身份验证等领域。本文将详细介绍如何使用 Python 和 OpenCV 库实现实时人脸识别,并通过具体的代码示例来展示整个过程。

环境准备

在开始编写代码之前,确保已经安装了 OpenCV 库。可以使用以下命令安装:

pip install opencv-python

代码详解

1. 导入必要的模块

import cv2

import cv2:导入 OpenCV 库,用于图像处理和人脸识别。

2. 定义主函数

def main():
    # 加载Haar级联分类器
    face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml')
    '''
    加载 Haar 级联分类器:
    face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml')
    cv2.CascadeClassifier():这是 OpenCV 中的一个类,用于加载预先训练好的 Haar 级联分类器。
    cv2.data.haarcascades + 'haarcascade_frontalface_default.xml':这是 OpenCV 自带的预训练 Haar 级联分类器文件路径,用于检测正面人脸。
    '''
    # 打开默认摄像头
    cap = cv2.VideoCapture(0)
    '''
    打开默认摄像头:
    cap = cv2.VideoCapture(0)
    cv2.VideoCapture():这是 OpenCV 中的一个类,用于捕获视频。参数 0 表示打开默认摄像头。
    '''
    while True:
        # 读取视频流中的一帧
        ret, frame = cap.read()
        '''
        读取视频流中的一帧:
        ret, frame = cap.read()
        cap.read():从摄像头读取一帧图像。返回两个值:
        ret:布尔值,表示读取是否成功。如果读取成功,ret 为 True;否则为 False。
        frame:读取到的图像帧。
        '''
        if not ret:
            break
        '''
        检查读取是否成功:
        if not ret:
            break
        如果读取失败(例如摄像头断开连接),则退出循环。
        '''
        # 将帧转换为灰度,因为 Haar 级联分类器需要灰度图像
        gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
        '''
        将帧转换为灰度:
        gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
        cv2.cvtColor():这是 OpenCV 中的一个函数,用于颜色空间转换。
        frame:输入图像。
        cv2.COLOR_BGR2GRAY:将 BGR 图像转换为灰度图像。
        '''
        # 检测人脸
        faces = face_cascade.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30),
                                             flags=cv2.CASCADE_SCALE_IMAGE)
        '''
        检测人脸:
        faces = face_cascade.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30),
                                             flags=cv2.CASCADE_SCALE_IMAGE)
        face_cascade.detectMultiScale():这是 Haar 级联分类器的一个方法,用于检测图像中的人脸。
        gray:输入的灰度图像。
        scaleFactor=1.1:每次图像尺寸减小的比例。
        minNeighbors=5:每个候选矩形应保留的邻居数阈值。
        minSize=(30, 30):最小检测人脸的尺寸。
        flags=cv2.CASCADE_SCALE_IMAGE:用于优化检测过程的标志。
        '''
        # 在检测到的人脸周围绘制矩形
        for (x, y, w, h) in faces:
            cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)
            '''
            在检测到的人脸周围绘制矩形:
            for (x, y, w, h) in faces:
                cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)
            for (x, y, w, h) in faces:遍历检测到的每个人脸。
            cv2.rectangle():这是 OpenCV 中的一个函数,用于在图像上绘制矩形。
            frame:输入图像。
            (x, y):矩形左上角的坐标。
            (x + w, y + h):矩形右下角的坐标。
            (0, 255, 0):矩形的颜色(绿色)。
            2:矩形线条的厚度。
            '''
        # 显示结果帧
        cv2.imshow('Face Detection', frame)
        '''
        显示结果帧:
        cv2.imshow('Face Detection', frame)
        cv2.imshow():这是 OpenCV 中的一个函数,用于显示图像。
        'Face Detection':窗口标题。
        frame:要显示的图像。
        '''
        # 按'q'退出循环
        if cv2.waitKey(1) & 0xFF == ord('q'):
            break
        '''
        按'q'退出循环:
        if cv2.waitKey(1) & 0xFF == ord('q'):
            break
        cv2.waitKey(1):等待 1 毫秒,等待用户按键。
        & 0xFF:将按键值转换为 ASCII 码。
        ord('q'):获取字符 'q' 的 ASCII 码。
        如果用户按下 'q' 键,则退出循环。
        '''
    # 释放摄像头并关闭所有窗口
    cap.release()
    cv2.destroyAllWindows()
    '''
    释放摄像头并关闭所有窗口:
    cap.release()
    cv2.destroyAllWindows()
    cap.release():释放摄像头资源。
    cv2.destroyAllWindows():关闭所有 OpenCV 窗口。
    '''
if __name__ == "__main__":
    main()
  • def main()::定义主函数 main
  • face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml'):加载 Haar 级联分类器,用于检测正面人脸。
  • cap = cv2.VideoCapture(0):打开默认摄像头。
  • while True::进入无限循环,实时读取摄像头图像。
  • ret, frame = cap.read():从摄像头读取一帧图像。
  • if not ret::检查读取是否成功,如果失败则退出循环。
  • gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY):将图像转换为灰度图像。
  • faces = face_cascade.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30), flags=cv2.CASCADE_SCALE_IMAGE):检测图像中的人脸。
  • for (x, y, w, h) in faces::遍历检测到的每个人脸,并在图像上绘制矩形。
  • cv2.imshow('Face Detection', frame):显示带有矩形标记的图像。
  • if cv2.waitKey(1) & 0xFF == ord('q')::按 ‘q’ 键退出循环。
  • cap.release():释放摄像头资源。
  • cv2.destroyAllWindows():关闭所有 OpenCV 窗口。

测试

  • 确保你的摄像头正常工作。
  • 运行脚本:
python3 face_detection.py
  • 打开摄像头后,你会看到一个窗口显示实时视频流,并且在检测到的人脸周围绘制绿色矩形。
  • 按 ‘q’ 键退出程序。

总结

本文详细介绍了如何使用 Python 和 OpenCV 库实现实时人脸识别,并通过具体的代码示例展示了整个过程。通过使用 cv2.CascadeClassifier 加载预训练的 Haar 级联分类器,cv2.VideoCapture 打开摄像头,cv2.cvtColor 转换图像颜色空间,cv2.rectangle 绘制矩形,最终实现了在实时视频流中检测并标记人脸的功能。

到此这篇关于使用 Python 和 OpenCV 实现实时人脸识别的文章就介绍到这了,更多相关Python 和 OpenCV人脸识别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python中的计时器timeit的使用方法

    python中的计时器timeit的使用方法

    本篇文章主要介绍了python中的计时器timeit的使用方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • python rolling regression. 使用 Python 实现滚动回归操作

    python rolling regression. 使用 Python 实现滚动回归操作

    这篇文章主要介绍了python rolling regression. 使用 Python 实现滚动回归操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-06-06
  • python读取文件指定行内容实例讲解

    python读取文件指定行内容实例讲解

    在本篇文章里小编给大家整理的是关于python读取文件指定行内容实例讲解,需要的朋友们可以参考下。
    2020-03-03
  • Python安装使用命令行交互模块pexpect的基础教程

    Python安装使用命令行交互模块pexpect的基础教程

    Pexpect是一个纯Python模块,可以用来和ssh、ftp、passwd、telnet等命令行命令进行交互使用,在Linux系统下尤其好用,下面我们就来具体来看一下Python安装使用命令行交互模块pexpect的基础教程:
    2016-05-05
  • Python对象循环引用垃圾回收算法详情

    Python对象循环引用垃圾回收算法详情

    这篇文章主要介绍了Python对象循环引用垃圾回收算法详情,文章围绕主题展开详细的内容戒杀,具有一定的参考价值,感兴趣的小伙伴可以参考一下
    2022-09-09
  • Python 实现集合Set的示例

    Python 实现集合Set的示例

    这篇文章主要介绍了Python 实现集合Set的示例,帮助大家更好的理解和使用python,感兴趣的朋友可以了解下
    2020-12-12
  • Python实现的矩阵类实例

    Python实现的矩阵类实例

    这篇文章主要介绍了Python实现的矩阵类,结合完整实例形式分析了Python矩阵的定义、计算、转换等相关操作技巧,需要的朋友可以参考下
    2017-08-08
  • 用python绘制彩色螺旋线代码

    用python绘制彩色螺旋线代码

    大家好,本篇文章主要讲的是用python绘制彩色螺旋线代码,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01
  • python实现感知器

    python实现感知器

    这篇文章主要为大家详细介绍了python实现感知器的相关资料,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-12-12
  • pywinauto自动化测试使用经验

    pywinauto自动化测试使用经验

    本文主要介绍了pywinauto自动化测试使用经验,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03

最新评论