使用opencv实现视频中人脸图片的提取

一、先上代码

import cv2 #pip install opencv-python
import matplotlib.pyplot as plt #pip install matplotlib
data=cv2.VideoCapture(r'./video/1.mp4') #获取视频路径
j = 1 #第j张图片
face_cascade=cv2.CascadeClassifier('./xmlfile/haarcascade_frontalface_default.xml')#要提取opencv中一个xml文件
#提取人脸图片函数
def search_face(img):
    global j
    gray=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) #转为灰度图片,这样才能提取人脸
    faces=face_cascade.detectMultiScale(gray,1.3,5) #找人脸
    if faces==(): #如果某一帧找不到人脸,则返回0
        return 0
    else:
        for (x,y,w,h) in faces:
            try:
                img=img[y-20:y+h+20:,x-20:x+w+20:,:] #人脸的宽度长度
                cv2.imwrite(r'.\imgs\%d.jpg' % j, img) #写入本地
		print("第%d张人脸图片"%j)
                j = j + 1
            except:
                pass

ret, frame = data.read() #读取video
i=0
#如果ret不为空,即能在某一帧中提取人脸图片
while ret:
    ret, frame = data.read()
    if ret==True:
        i=i+1
        if i%20==0:
            search_face(frame)
    # 展示图片
    #     cv2.imshow('frame', frame)
    # if cv2.waitKey(5) & 0xFF == ord('q'):
    #     break
data.release() #释放内存
cv2.destroyAllWindows()

二、目录结构

使用opencv实现视频中人脸图片的提取_第1张图片
haar…xml文件来源如下:

使用opencv实现视频中人脸图片的提取_第2张图片
找到python的下载的库文件夹(一般都在“python版本”/Lib/site-packages中)再找到cv2,cv2下面会有几个文件夹,haar…xml文件不一定再data文件夹之中,可以在cv2下面的文件夹点开来找找。

三、运行结果

使用opencv实现视频中人脸图片的提取_第3张图片
使用opencv实现视频中人脸图片的提取_第4张图片
因隐私问题,具体的人脸图片就不展现出来了。

你可能感兴趣的:(服务外包竞赛,opencv,音视频,python)