#在这个python文件中,训练识别人脸
#我们使用的是openCV库提供的默认识别器
#我们还使用os模块来查找图像的目录
#我们将使用名为cv2.face.LBPHFaceRecognizer_create()的函数来实现识别器
#然后我们将使用Python pillow库从目录中加载图像
#我们还将使用Pickle库来存储标签
项目如图
Face_Recognition_Trainaing.py文件
#________________________Lets start the project_______________________#
FaceRecognition.py文件
import cv2#下载opencv-contrib-python
import numpy
import pickle
#打开摄像头
Webcam = cv2.VideoCapture(0)
# 加载OpenCV人脸检测分类器Haar
face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_alt2.xml')
Recognizer = cv2.face.LBPHFaceRecognizer_create()
Recognizer.read('Training.yml')
Labels = {}
with open('Label.pickle' , 'rb') as file:
OriginalLabel = pickle.load(file)
Labels = {v:k for k,v in OriginalLabel.items()}
while (True):
Return ,Frame =Webcam.read() #读取该帧的画面
Frame = cv2.flip(Frame , 1)
GrayScale = cv2.cvtColor(Frame , cv2.COLOR_BGR2GRAY)# 6灰度处理
Faces = face_cascade.detectMultiScale(GrayScale , 1.3 ,5)# 检查人脸
for X,Y,W,H in Faces:
ROI_GRAY = GrayScale[Y:Y+H , X:X+W]
ROI_COLOR = Frame[Y:Y+H , X:X+W]
ID , Confidence = Recognizer.predict(ROI_GRAY)#预测函数
if Confidence >= 45:
print(Labels[ID])
cv2.putText(Frame , Labels[ID],(X,Y) , cv2.FONT_HERSHEY_SIMPLEX , 1,(0,0,255),2)
cv2.rectangle(Frame , (X,Y) , (X+W , Y+H) , (255 , 0 , 0) , 1)
# 9显示图片
cv2.imshow('Image' , Frame)
# 10暂停窗口
if cv2.waitKey(1) == ord('q'):
break
# 11释放资源
Webcam.release()
# #12销毁窗口
cv2.destroyAllWindows()
参考:https://www.cnblogs.com/ningxinjie/p/11542950.html
为什么使用yml文件https://blog.csdn.net/sereasuesue/article/details/1052942364
Python数据存储:pickle模块的使用讲解https://blog.csdn.net/sereasuesue/article/details/105293917