opencv获取人脸眼镜位置_python openCV获取人脸部分并存储功能

这篇博客介绍了如何使用Python的OpenCV库来检测和存储人脸,特别是眼镜部位。通过加载预训练的面部检测模型,从摄像头捕获图像,然后对灰度图像进行处理,找出人脸区域。检测到的人脸部分被保存为单独的图像文件。
摘要由CSDN通过智能技术生成

本文实例为大家分享了python openCV获取人脸部分并存储的具体代码,供大家参考,具体内容如下

#-*- 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批量检测人脸,并保存:

import cv2

import sys

import os

from PIL import Image

cascPath = "haarcascade_frontalface_default.xml" #训练参数文件

faceCascade = cv2.CascadeClassifier(cascPath)#分类器

base = 'new_dir\\'

for img in os.listdir(base):

image = cv2.imread(base + img)#读取图片

gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

gray = cv2.equalizeHist(gray) #直方图均衡化,提高分类效果

faces = faceCascade.detectMultiScale(

gray,

scaleFactor=1.1,

minNeighbors=5,

minSize=(10, 10)

)

num = 0

for (x, y, w, h) in faces:

cv2.imwrite("face_dir\\" + img,image[y:y+h,x:x+w])

num += 1

# cv2.imshow("Faces found", image)

cv2.waitKey(0)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

本文标题: python openCV获取人脸部分并存储功能

本文地址: http://www.cppcns.com/jiaoben/python/270793.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值