Python下应用opencv 实现人脸检测功能


Posted in Python onOctober 24, 2019

使用OpenCV's Haar cascades作为人脸检测,因为他做好了库,我们只管使用。

代码简单,除去注释,总共有效代码只有10多行。

所谓库就是一个检测人脸的xml 文件,可以网上查找,下面是一个地址:

https://github.com/opencv/opencv/blob/master/data/haarcascades/haarcascade_frontalface_default.xml

如何构造这个库,学习完本文后可以参考:

http://note.sonots.com/SciSoftware/haartraining.html

https://www.instructables.com/id/Create-OpenCV-Image-Classifiers-Using-Python/

知道构造库,就可以检测各种你想要检测的东西了。

人脸检测不是人脸识别,但是人脸识别的前提。

运行效果如下:

Python下应用opencv 实现人脸检测功能

前提:

这个原始代码来自 https://www.pyimagesearch.com/2016/11/21/raspbian-opencv-pre-configured-and-pre-installed/ 的一个教学讲稿。

你需要下载haarcascade_frontalface_default.xml 以及准备你要检测的文件,我这里是family.jpg,放在python 文件detect_faces.py 所在目录(工作目录)的子目录images下。haarcascade_frontalface_default.xml是放在工作目录。

如果加上摄像头连接程序,也可实时检测,另文介绍。

代码1介绍

导入库,并做命令行参数处理。你在命令行可以输入如下:

python detect_faces.py --image image/family.jpg  --detector haarcascade_frontalface_default.xml

我在程序中都有缺省参数处理,你如果集成测试或命令行不输参数的话,就要修改好你的缺省值。

这样命令行就是python detect_faces.py ,同时也可以输入命令行输入参数。

# USAGE 使用方法是:
# python detect_faces.py --image images/family.jpg \
# --detector haarcascade_frontalface_default.xml
# import the necessary packages 输入包
# import imutils 
import argparse
import cv2
# construct the argument parser and parse the arguments //构造命令行参数分析
# 为了集成测试,或者命令行输入的简单,这里都有缺省参数
#image 是 images/family.jpg
#detector 是 haarcascade_frontalface_default.xml
ap = argparse.ArgumentParser()
ap.add_argument("-i", "--image", default='images/family.jpg',
 help="path to the input image")
ap.add_argument("-d", "--detector", default='haarcascade_frontalface_default.xml',
 help="path to Haar cacscade face detector")
args = vars(ap.parse_args())
 导入图形文件,并灰度处理
# load our image and convert it to grayscale 导入图形文件,并灰度化
image = cv2.imread(args["image"])
#image =imutils.resize(image,width=800)
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
导入检测文件,检测图中人脸,显示检测到的人脸数
# load the face detector and detect faces in the image
# 导入脸部检测文件
detector = cv2.CascadeClassifier(args["detector"])
#检测图形中的脸部
rects = detector.detectMultiScale(gray, scaleFactor=1.05, minNeighbors=9,
 minSize=(40, 40), flags=cv2.CASCADE_SCALE_IMAGE)
#显示检测到的人脸数目
print("[INFO] detected {} faces".format(len(rects)))
 循环,绘图每个检测到的人脸框,并图形显示
# load the face detector and detect faces in the image
# 导入脸部检测
detector = cv2.CascadeClassifier(args["detector"])
#检测图形中的脸部
rects = detector.detectMultiScale(gray, scaleFactor=1.05, minNeighbors=9,
 minSize=(40, 40), flags=cv2.CASCADE_SCALE_IMAGE)
#显示检测到的人脸数目
print("[INFO] detected {} faces".format(len(rects)))

最后串接所有代码如下:

# USAGE 使用方法是:
# python detect_faces.py --image images/family.jpg \
# --detector haarcascade_frontalface_default.xml
# import the necessary packages 输入包
# import imutils 如果需要成比例缩放图形才需要,这里不需要
import argparse
import cv2
# construct the argument parser and parse the arguments //构造命令行参数分析
# 为了集成测试,或者命令行输入的简单,这里都有缺省参数
#image 是 images/family.jpg
#detector 是 haarcascade_frontalface_default.xml
ap = argparse.ArgumentParser()
ap.add_argument("-i", "--image", default='images/family.jpg',
 help="path to the input image")
ap.add_argument("-d", "--detector", default='haarcascade_frontalface_default.xml',
 help="path to Haar cacscade face detector")
args = vars(ap.parse_args())
# load our image and convert it to grayscale 导入图形文件,并灰度化
image = cv2.imread(args["image"])
#image =imutils.resize(image,width=800)
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
# load the face detector and detect faces in the image
# 导入脸部检测文件
detector = cv2.CascadeClassifier(args["detector"])
#检测图形中的脸部
rects = detector.detectMultiScale(gray, scaleFactor=1.05, minNeighbors=9,
 minSize=(40, 40), flags=cv2.CASCADE_SCALE_IMAGE)
#显示检测到的人脸数目
print("[INFO] detected {} faces".format(len(rects)))
# loop over the bounding boxes and draw a rectangle around each face
# 循环rects,绘图每个检测到的人脸框
for (x, y, w, h) in rects:
 cv2.rectangle(image, (x, y), (x + w, y + h), (0, 255, 0), 2)
# show the detected faces
cv2.imshow("Faces", image)
cv2.waitKey(0)

总结

以上所述是小编给大家介绍的Python下应用opencv 实现人脸检测功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
python静态方法实例
Jan 14 Python
Python处理RSS、ATOM模块FEEDPARSER介绍
Feb 18 Python
在Python中用has_key()方法查找键是否存在的教程
May 21 Python
剖析Python的Twisted框架的核心特性
May 25 Python
Python实现爬虫设置代理IP和伪装成浏览器的方法分享
May 07 Python
Win8下python3.5.1安装教程
Jul 29 Python
对numpy中数组转置的求解以及向量内积计算方法
Oct 31 Python
python requests.post带head和body的实例
Jan 02 Python
python实现倒计时小工具
Jul 29 Python
TensorFlow:将ckpt文件固化成pb文件教程
Feb 11 Python
详解python算法常用技巧与内置库
Oct 17 Python
Python环境搭建过程从安装到Hello World
Feb 05 Python
Python迭代器iterator生成器generator使用解析
Oct 24 #Python
Python 取numpy数组的某几行某几列方法
Oct 24 #Python
Django和Flask框架优缺点对比
Oct 24 #Python
python命令 -u参数用法解析
Oct 24 #Python
使用python制作游戏下载进度条的代码(程序说明见注释)
Oct 24 #Python
用Python解数独的方法示例
Oct 24 #Python
Python3 sys.argv[ ]用法详解
Oct 24 #Python
You might like
在普通HTTP上安全地传输密码
2007/07/21 PHP
CURL的学习和应用(附多线程实现)
2013/06/03 PHP
php 判断是否是中文/英文/数字示例代码
2013/09/30 PHP
PHP实现采集抓取淘宝网单个商品信息
2015/01/08 PHP
PHP读取zip文件的方法示例
2016/11/17 PHP
PHP实现的pdo连接数据库并插入数据功能简单示例
2019/03/30 PHP
关于 文本框默认值 的操作js代码
2012/01/12 Javascript
javascript的offset、client、scroll使用方法详解
2012/12/25 Javascript
struts2+jquery+json实现异步加载数据(自写)
2013/06/24 Javascript
jquery解析XML字符串和XML文件的方法说明
2014/02/21 Javascript
Jquery通过JSON字符串创建JSON对象
2014/08/24 Javascript
使用jquery动态加载Js文件和Css文件
2015/10/24 Javascript
轻松掌握JavaScript策略模式
2016/08/25 Javascript
微信小程序 条件渲染详解
2016/10/09 Javascript
基于jQuery制作小图标上下滑动特效
2017/01/18 Javascript
js评分组件使用详解
2017/06/06 Javascript
浅谈Vue 初始化性能优化
2017/08/31 Javascript
浅谈JsonObject中的key-value数据解析排序问题
2017/12/06 Javascript
vue+webpack dev本地调试全局样式引用失效的解决方案
2019/11/12 Javascript
swiper实现异形轮播效果
2019/11/28 Javascript
为Python的web框架编写前端模版的教程
2015/04/30 Python
对tf.reduce_sum tensorflow维度上的操作详解
2018/07/26 Python
在Mac上删除自己安装的Python方法
2018/10/29 Python
python多线程http压力测试脚本
2019/06/25 Python
Python中filter与lambda的结合使用详解
2019/12/24 Python
Pytorch数据拼接与拆分操作实现图解
2020/04/30 Python
Python‘==‘ 及 ‘is‘相关原理解析
2020/09/05 Python
HTML5实现简单图片上传所遇到的问题及解决办法
2016/01/20 HTML / CSS
企业法人代表任命书
2014/06/06 职场文书
化工见习报告范文
2014/10/31 职场文书
2014年老干部工作总结
2014/11/21 职场文书
2014年挂职干部工作总结
2014/12/06 职场文书
2014年生活老师工作总结
2014/12/23 职场文书
中标通知书
2015/04/17 职场文书
2016年少先队活动总结
2016/04/06 职场文书
解决Vue+SpringBoot+Shiro跨域问题
2021/06/09 Vue.js