#-*- coding:utf-8 -*-
import cv2
import os
import time
import base64
import numpy as np
save_path = 'E:\\opencv\\2018-04-24OpenCv\\RAR\\savetest'
faceCascade = cv2.CascadeClassifier(
'./haarcascade_frontalface_alt.xml')
cap = cv2.VideoCapture(0)
count = 0
while True:
ret,frame = cap.read()
gray = cv2.cvtColor(frame,cv2.COLOR_RGB2GRAY)
rect = faceCascade.detectMultiScale(gray,
scaleFactor=1.3,
minNeighbors=9,
minSize=(50,50),
flags=cv2.CASCADE_SCALE_IMAGE
)
if not rect is ():
for x,y,w,h in rect:
roiImg = frame[y:y+h,x:x+w]
# 以时间戳和读取的排序作为文件名称
listStr = [str(int(time.time())), str(count)]
fileName = ''.join(listStr)
# 图片存储
cv2.imwrite(save_path + os.sep + '%s.jpg' % fileName, roiImg)
# print (roiImg)
# roiTobase64 = cv2.imencode(roiImg,np.uint8)
# print (base64.b64encode(roiTobase64))
cv2.rectangle(frame,(x,y),(x+w,y+h),(0,0,255),2)
count += 1
cv2.imshow('opencvCut',frame)
k = cv2.waitKey(30) & 0xff
if k == 27:
break
cap.release()
cv2.destroyAllWindows()
Python openCV 获取人脸部分并存储
最新推荐文章于 2024-07-09 17:57:14 发布