python3.6 open3.4 人脸定位案例

python3.6 open3.4 人脸识别。搞了半天,记录下走过的坑。
能够检测人脸,还有眼睛。
先上效果:
python

代码以下:code

import cv2
import sys
import os
# Get user supplied values
imagePath = './heying5.jpg'#sys.argv[1]
# Create the haar cascade

faceCascade=cv2.CascadeClassifier('D:\opencv\sources\data\haarcascades\haarcascade_frontalface_default.xml')#
eyeCascade = cv2.CascadeClassifier("D:\opencv\sources\data\haarcascades\haarcascade_eye.xml")
if 
# Read the image
image = cv2.imread(imagePath)#2
# cv2.imshow("frame" , image)
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)#3
# cv2.imshow("frame" , gray)
# Detect faces in the image
faces = faceCascade.detectMultiScale(gray,scaleFactor=1.15,minNeighbors=5,minSize=(5,5))
    #flags=cv2.CASCADE_SCALE_IMAGE

#faceCascade.detectMultiScale(gray, scaleFactor = 1.3, minNeighbors = 4, minSize = (32, 32))
print("Found {0} faces!".format(len(faces)))#5
for (x, y, w, h) in faces:
    cv2.rectangle(image, (x, y), (x+w, y+h), (0, 255, 0), 2) #6
    roi_gray_img = gray[y:y + h, x:x + w]
    roi_img = image[y:y + h, x:x + w]
    eyes = eyeCascade.detectMultiScale(roi_gray_img, 1.3, 5)
    for eye_x, eye_y, eye_w, eye_h in eyes:
        cv2.rectangle(roi_img, (eye_x, eye_y), (eye_x + eye_w, eye_y + eye_h), (255, 0, 0), 2)

cv2.imshow("Faces found", image)#7
cv2.waitKey(0) #8


注意:
坑1:orm

faceCascade=cv2.CascadeClassifier('D:\opencv\sources\data\haarcascades\haarcascade_frontalface_default.xml')

不少文章直接写成:xml

faceCascade=cv2.CascadeClassifier('haarcascade_frontalface_default.xml')

假如代码运行出错,找不到haarcascade_frontalface_default.xml文件,必需要单独安装opencv的exe的压缩包,解压缩后,里面会有此xml文件,而后把全地址填到这里。博客

坑2:
不少博客是基于opencv2.x版本的,个人环境是opencv3.4的。3.4中cv2.cv已经没了....通常状况直接把cv2.cv.xxx改为cv2.xxx就行。假如不行的,百度看看换成其余什么了。it

相关文章
相关标签/搜索