Python学习笔记之图片人脸检测识别实例教程


Posted in Python onMarch 06, 2019

前言

随着科技的发展,人脸识别技术在许多领域得到的非常广泛的应用,手机支付、银行身份验证、手机人脸解锁等等。

识别

废话少说,这里我们使用 opencv 中自带了 haar人脸特征分类器,利用训练好的 haar 特征的 xml 文件,在图片上检测出人脸的坐标,利用这个坐标,我们可以将人脸区域剪切保存,也可以在原图上将人脸框出。

代码实现:

# -*-coding:utf8-*-#
import os
import cv2
from PIL import Image, ImageDraw
from datetime import datetime

"""
分类器 https://github.com/opencv/opencv/tree/master/data/haarcascades
安装模块:pip install Pillow pip install opencv-python
博客:https://blog.52itstyle.vip/archives/3771/
"""


def detectFaces(image_name):
 img = cv2.imread(image_name)
 face_cascade = cv2.CascadeClassifier(os.getcwd()+"\\haarcascade\\haarcascade_frontalface_alt.xml")
 if img.ndim == 3:
  gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
 else:
  gray = img # if语句:如果img维度为3,说明不是灰度图,先转化为灰度图gray,如果不为3,也就是2,原图就是灰度图

 faces = face_cascade.detectMultiScale(gray, 1.2, 5) # 1.3和5是特征的最小、最大检测窗口,它改变检测结果也会改变
 result = []
 for (x, y, width, height) in faces:
  result.append((x, y, x + width, y + height))
 return result


# 保存人脸图
def saveFaces(image_name):
 faces = detectFaces(image_name)
 if faces:
  # 将人脸保存在save_dir目录下。
  # Image模块:Image.open获取图像句柄,crop剪切图像(剪切的区域就是detectFaces返回的坐标),save保存。
  save_dir = image_name.split('.')[0] + "_faces"
  os.mkdir(save_dir)
  count = 0
  for (x1, y1, x2, y2) in faces:
   file_name = os.path.join(save_dir, str(count) + ".jpg")
   Image.open(image_name).crop((x1, y1, x2, y2)).save(file_name)
   count += 1


if __name__ == '__main__':
 time1 = datetime.now()
 result = detectFaces(os.getcwd()+"\\images\\gaoyuanyuan.jpg")
 time2 = datetime.now()
 print("耗时:" + str(time2 - time1))
 if len(result) > 0:
  print("有人存在!!---》人数为:" + str(len(result)))
 else:
  print('视频图像中无人!!')

 drawFaces(os.getcwd()+"\\images\\", "hanxue.jpg")
 saveFaces(os.getcwd()+\\images\\gaoyuanyuan.jpg)

识别效果图:

Python学习笔记之图片人脸检测识别实例教程

多人识别效果:

Python学习笔记之图片人脸检测识别实例教程

经过测试,最终选用了 haarcascade_frontalface_alt.xml 做人脸识别,识别率最高。

人脸检测分类器对比:

级联分类器的类型 XML文件名
人脸检测器(默认) haarcascade_frontalface_default.xml
人脸检测器(快速的Haar) haarcascade_frontalface_alt2.xml
人脸检测器(Tree) haarcascade_frontalface_alt_tree.xml
人脸检测器(Haar_1) haarcascade_frontalface_alt.xml

小结

开源的人脸检测分类器对于标准的人脸识别足够了,要想精确识别比如,侧脸、模糊、光照、遮挡的人脸,只能通过深度机器学习进一步优化识别精度和速度。

源码

https://gitee.com/52itstyle/Python/tree/master/Day09(本地下载)

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
python使用urllib2模块获取gravatar头像实例
Dec 18 Python
python 开发的三种运行模式详细介绍
Jan 18 Python
Python实现将一个大文件按段落分隔为多个小文件的简单操作方法
Apr 17 Python
Python3解决棋盘覆盖问题的方法示例
Dec 07 Python
python正则实现计算器功能
Dec 14 Python
pytorch + visdom 处理简单分类问题的示例
Jun 04 Python
OPENCV去除小连通区域,去除孔洞的实例讲解
Jun 21 Python
python消除序列的重复值并保持顺序不变的实例
Nov 08 Python
Django框架orM与自定义SQL语句混合事务控制操作
Jun 27 Python
python模块hashlib(加密服务)知识点讲解
Nov 25 Python
将 Ubuntu 16 和 18 上的 python 升级到最新 python3.8 的方法教程
Mar 11 Python
pycharm导入源码的具体步骤
Aug 04 Python
详解django2中关于时间处理策略
Mar 06 #Python
Django使用AJAX调用自己写的API接口的方法
Mar 06 #Python
Django+Xadmin构建项目的方法步骤
Mar 06 #Python
Python中最大递归深度值的探讨
Mar 05 #Python
Python小进度条显示代码
Mar 05 #Python
Python嵌套式数据结构实例浅析
Mar 05 #Python
Python字典遍历操作实例小结
Mar 05 #Python
You might like
PHP数组排序函数合集 以及它们之间的联系分析
2013/06/27 PHP
php安装ssh2扩展的方法【Linux平台】
2016/07/20 PHP
jQuery ajax+PHP实现的级联下拉列表框功能示例
2019/02/12 PHP
CI(CodeIgniter)框架中URL特殊字符处理与SQL注入隐患分析
2019/02/28 PHP
JS 的应用开发初探(mootools)
2009/12/19 Javascript
JQuery下的Live方法和$.browser方法使用代码
2010/06/02 Javascript
关于捕获用户何时点击window.onbeforeunload的取消事件
2011/03/06 Javascript
javascript中的self和this用法小结
2014/02/08 Javascript
深入浅出ES6新特性之函数默认参数和箭头函数
2016/08/01 Javascript
JavaScript正则替换HTML标签功能示例
2017/03/02 Javascript
如何在Vue.JS中使用图标组件
2020/08/04 Javascript
JS+CSS实现动态时钟
2021/02/19 Javascript
[43:33]EG vs Spirit Supermajor 败者组 BO3 第一场 6.4
2018/06/05 DOTA
Python datetime时间格式化去掉前导0
2014/07/31 Python
Linux环境下MySQL-python安装过程分享
2015/02/02 Python
如何使用七牛Python SDK写一个同步脚本及使用教程
2015/08/23 Python
Python实现繁?转为简体的方法示例
2018/12/18 Python
基于Python的图像数据增强Data Augmentation解析
2019/08/13 Python
Python Pillow.Image 图像保存和参数选择方式
2020/01/09 Python
python 的topk算法实例
2020/04/02 Python
Python PIL库图片灰化处理
2020/04/07 Python
Python3交互式shell ipython3安装及使用详解
2020/07/11 Python
Window10上Tensorflow的安装(CPU和GPU版本)
2020/12/15 Python
举例讲解Python装饰器
2020/12/24 Python
使用HTML和CSS实现的标签云效果(附demo)
2021/02/03 HTML / CSS
Linux如何为某个操作添加别名
2013/03/01 面试题
历史学专业推荐信
2013/11/06 职场文书
审核会计岗位职责
2013/11/08 职场文书
企划专员岗位职责
2013/12/09 职场文书
教育孩子心得体会
2014/01/01 职场文书
社会治安综合治理管理责任书
2014/04/16 职场文书
毕业证代领委托书
2014/09/26 职场文书
县人大领导班子四风对照检查材料思想汇报
2014/10/09 职场文书
龙潭大峡谷导游词
2015/02/10 职场文书
繁星春水读书笔记
2015/06/30 职场文书
Redis批量生成数据的实现
2022/06/05 Redis