本文實例為大家分享了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)
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

