提示信息

基于 OpenCV 和 Python 的人脸识别签到系统的保姆级教程

平庸 已关注

创建一个基于 OpenCV 和 Python 的人脸识别签到系统可以是一个有趣且具有挑战性的项目。以下是一个简化的保姆级教程,帮助你入门。

先决条件

在开始之前,请确保你已经安装了以下软件和库:

  • Python 3.x
  • OpenCV (opencv-python)
  • Numpy
  • Pillow(用于图像处理)
  • dlib(用于人脸识别)
  • face_recognition(基于 dlib 的人脸识别库)

你可以通过以下命令进行安装:

  1. pip install opencv-python numpy pillow dlib face_recognition

步骤 1:设置人脸数据

首先,你需要收集签到人员的脸部图像。可以创建一个名为 known_faces 的文件夹,并在其中存放人员的脸部照片。确保每个图像文件命名为与其对应的姓名相同。

步骤 2:加载并编码已知人脸

创建一个 Python 文件(比如 face_recognition_attendance.py),并编写以下代码:

  1. import face_recognition
  2. import cv2
  3. import numpy as np
  4. import os
  5. # 加载已知的脸部
  6. known_face_encodings = []
  7. known_face_names = []
  8. known_faces_dir = 'known_faces'
  9. for image_name in os.listdir(known_faces_dir):
  10. image_path = os.path.join(known_faces_dir, image_name)
  11. image = face_recognition.load_image_file(image_path)
  12. face_encoding = face_recognition.face_encodings(image)[0]
  13. known_face_encodings.append(face_encoding)
  14. # 删除文件扩展名
  15. known_face_names.append(os.path.splitext(image_name)[0])
  16. print("已知人脸加载完毕")

步骤 3:实施实时人脸识别

接下来,我们使用电脑摄像头来捕获视频帧并进行人脸识别:

  1. # 打开摄像头
  2. video_capture = cv2.VideoCapture(0)
  3. while True:
  4. # 捕获视频的一帧
  5. ret, frame = video_capture.read()
  6. # 将视频帧从 BGR(OpenCV 默认)转换为 RGB(face_recognition 默认)
  7. rgb_frame = frame[:, :, ::-1]
  8. # 找到当前帧中的所有人脸和脸部编码
  9. face_locations = face_recognition.face_locations(rgb_frame)
  10. face_encodings = face_recognition.face_encodings(rgb_frame, face_locations)
  11. for (top, right, bottom, left), face_encoding in zip(face_locations, face_encodings):
  12. matches = face_recognition.compare_faces(known_face_encodings, face_encoding)
  13. name = "Unknown"
  14. # 如果在人脸数据库中找到匹配的
  15. face_distances = face_recognition.face_distance(known_face_encodings, face_encoding)
  16. best_match_index = np.argmin(face_distances)
  17. if matches[best_match_index]:
  18. name = known_face_names[best_match_index]
  19. # 绘制人脸的矩形框和名字
  20. cv2.rectangle(frame, (left, top), (right, bottom), (0, 0, 255), 2)
  21. cv2.putText(frame, name, (left, top - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 0, 255), 2)
  22. # 显示结果帧
  23. cv2.imshow('Face Recognition', frame)
  24. # 按下 'q' 键退出
  25. if cv2.waitKey(1) & 0xFF == ord('q'):
  26. break
  27. # 释放摄像头和关闭窗口
  28. video_capture.release()
  29. cv2.destroyAllWindows()

步骤 4:实现签到功能

为了实现签到功能,你可以将识别到的人脸信息记录在日志文件中:

  1. import csv
  2. from datetime import datetime
  3. def mark_attendance(name):
  4. with open('attendance_log.csv', 'a', newline='') as file:
  5. writer = csv.writer(file)
  6. now = datetime.now()
  7. dt_string = now.strftime('%Y-%m-%d %H:%M:%S')
  8. writer.writerow([name, dt_string])
  9. # 在识别出名字之后调用 mark_attendance(name)
  10. if matches[best_match_index]:
  11. name = known_face_names[best_match_index]
  12. mark_attendance(name)

注意事项

  • 建议在实验室条件下测试脚本,在项目集成之前确保一切功能正常。
  • 请注意拍摄环境的光线和背景条件。
  • 确保你的 dlib 库正确安装,因为它需要 CMake 和一些编译工具支持。

这样,你就有了一个基本的基于 Python 和 OpenCV 的人脸识别签到系统。可以根据需要进一步拓展,例如增加 UI 界面,或与其他考勤系统集成。

    遇到难题? "AI大模型GPT4.0、GPT" 是你的私人解答专家! 点击按钮去提问......
平庸 关注 已关注

最近一次登录:2024-11-21 01:06:32   

暂时还没有签名,请关注我或评论我的文章
×
免费图表工具,画流程图、架构图