python+opencv,5行代码,最简单的人脸检测方法

本文详细介绍了一个基于Python和OpenCV的人脸检测项目。作者在Win10环境下,使用Python3.6和OpenCV3.4,仅用5行核心代码实现了人脸检测功能。代码中包含了获取训练数据、读取图片并转换为灰度图、检测人脸坐标及绘制检测框的过程。通过实例展示了从原始图片到检测结果的完整流程。

首先,介绍下开发环境,我使用的是win10+python3.6+opencv3.4。
下面直接上代码。

import cv2
# 获取训练好的人脸的参数数据,这里是数据是opencv自带的,cv2.haarcascades表示cv2的安装地址
face_cascade = cv2.CascadeClassifier(cv2.haarcascades+'haarcascade_frontalface_default.xml')
# 读取图片,并获得灰度图
image = cv2.imread('IMG_0296.JPG')
gray = cv2.cvtColor(image,cv2.COLOR_BGR2GRAY)
# 检测人脸,返回人脸的坐标
faces = face_cascade.detectMultiScale(gray,scaleFactor=1.15,minNeighbors=5,minSize=(5,5))
# 画图
for(x,y,w,h) in faces:
    cv2.rectangle(image,(x,y),(x+w,y+h),(0,255,0),4)
# 保存图片
cv2.imwrite('./face.jpg', image)

最简单的人脸检测代码了,不算画图和保存,只用的5行代码,其实核心就两行代码,一行是获取数据,一行是检测人脸。下面我们看一下结果。

原始图片:
在这里插入图片描述

检测后的图片:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值