python+opencv实现的简单人脸识别代码示例


Posted in Python onNovember 14, 2017

#
源码如下:

#!/usr/bin/env python
#coding=utf-8
import os
from PIL import Image, ImageDraw
import cv
def detect_object(image):
 '''检测图片,获取人脸在图片中的坐标'''
 grayscale = cv.CreateImage((image.width, image.height), 8, 1)
 cv.CvtColor(image, grayscale, cv.CV_BGR2GRAY)
 cascade = cv.Load("/opt/local/share/OpenCV/haarcascades/haarcascade_frontalface_alt_tree.xml")
 rect = cv.HaarDetectObjects(grayscale, cascade, cv.CreateMemStorage(), 1.1, 2,
  cv.CV_HAAR_DO_CANNY_PRUNING, (20,20))
 result = []
 for r in rect:
  result.append((r[0][0], r[0][1], r[0][0]+r[0][2], r[0][1]+r[0][3]))
 return result
def process(infile):
 '''在原图上框出头像并且截取每个头像到单独文件夹'''
 image = cv.LoadImage(infile);
 if image:
  faces = detect_object(image)
 im = Image.open(infile)
 path = os.path.abspath(infile)
 save_path = os.path.splitext(path)[0]+"_face"
 try:
  os.mkdir(save_path)
 except:
  pass
 if faces:
  draw = ImageDraw.Draw(im)
  count = 0
  for f in faces:
   count += 1
   draw.rectangle(f, outline=(255, 0, 0))
  drow_save_path = os.path.join(save_path,"out.jpg")
  im.save(drow_save_path, "JPEG", quality=80)
 else:
  print "Error: cannot detect faces on %s" % infile
if __name__ == "__main__":
 process("/Users/zhangdebin/Documents/checkFace2.jpg")

示例图片1:

python+opencv实现的简单人脸识别代码示例

可以看出,对于比较干净的人脸头像,使用opencv库haarcascade_frontalface_alt_tree.xml的识别精度很高(这张达到了100%),同时,对于表情变化的人脸也有很强的鲁棒性。

示例图片2:

python+opencv实现的简单人脸识别代码示例

但是,对于上传的比较随意的头像照片,比如示例图片2这些有帽子、眼镜遮挡的人脸图片,识别效果就会很差,本组只有唯一一个没有帽子遮挡的人脸被识别成功

本次只是简单的测试了下,python使用opencv库的人脸特征进行人脸识别的效果,仅供初学参考。

总结

以上就是本文关于python+opencv实现的简单人脸识别代码示例的全部内容,希望对大家有所帮助,感兴趣的朋友可以参阅本站:

如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

Python 相关文章推荐
python使用os模块的os.walk遍历文件夹示例
Jan 27 Python
wxPython使用系统剪切板的方法
Jun 16 Python
使用C++扩展Python的功能详解
Jan 12 Python
用python与文件进行交互的方法
Mar 01 Python
opencv改变imshow窗口大小,窗口位置的方法
Apr 02 Python
Python WSGI的深入理解
Aug 01 Python
Python中staticmethod和classmethod的作用与区别
Oct 11 Python
python自制包并用pip免提交到pypi仅安装到本机【推荐】
Jun 03 Python
Pytorch卷积层手动初始化权值的实例
Aug 17 Python
在ipython notebook中使用argparse方式
Apr 20 Python
Python实现Telnet自动连接检测密码的示例
Apr 16 Python
使用Python+OpenCV进行卡类型及16位卡号数字的OCR功能
Aug 30 Python
解读! Python在人工智能中的作用
Nov 14 #Python
python利用有道翻译实现"语言翻译器"的功能实例
Nov 14 #Python
TensorFlow在MAC环境下的安装及环境搭建
Nov 14 #Python
python中文分词,使用结巴分词对python进行分词(实例讲解)
Nov 14 #Python
Python中import机制详解
Nov 14 #Python
AI人工智能 Python实现人机对话
Nov 13 #Python
Python编程实现蚁群算法详解
Nov 13 #Python
You might like
咖啡豆的最常见发酵处理方法,详细了解一下
2021/03/03 冲泡冲煮
也谈php网站在线人数统计
2008/04/09 PHP
PHP 页面编码声明方法详解(header或meta)
2010/03/12 PHP
PHP 中文处理技巧
2010/04/25 PHP
jQuery AJAX回调函数this指向问题
2010/02/08 Javascript
JS分页效果示例
2013/10/11 Javascript
js对字符串进行编码的方法总结(推荐)
2016/11/10 Javascript
jquery select2的使用心得(推荐)
2016/12/04 Javascript
nodejs集成sqlite使用示例
2017/06/05 NodeJs
BootStrap数据表格实例代码
2017/09/13 Javascript
微信小程序中时间戳和日期的相互转换问题
2018/07/09 Javascript
angularjs的单选框+ng-repeat的实现方法
2018/09/12 Javascript
javacript replace 正则取字符串中的值并替换【推荐】
2018/09/13 Javascript
JavaScript如何获取一个元素的样式信息
2019/07/29 Javascript
解决layui动态加载复选框无法选中的问题
2019/09/20 Javascript
Vue指令实现OutClick的示例
2020/11/16 Javascript
仅用50行Python代码实现一个简单的代理服务器
2015/04/08 Python
Python加密方法小结【md5,base64,sha1】
2017/07/13 Python
Python爬虫框架Scrapy实例代码
2018/03/04 Python
Python读取Excel表格,并同时画折线图和柱状图的方法
2018/10/14 Python
使用python进行波形及频谱绘制的方法
2019/06/17 Python
Python编写打字训练小程序
2019/09/26 Python
利用python实现.dcm格式图像转为.jpg格式
2020/01/13 Python
在Sublime Editor中配置Python环境的详细教程
2020/05/03 Python
HTML5中使用postMessage实现Ajax跨域请求的方法
2016/04/19 HTML / CSS
html5拖曳操作 HTML5实现网页元素的拖放操作
2013/01/02 HTML / CSS
html5通过canvas实现刮刮卡效果示例分享
2014/01/27 HTML / CSS
匡威意大利官方商店 :Converse意大利
2018/11/27 全球购物
索引覆盖(Index Covering)查询含义
2012/02/18 面试题
经济管理专业毕业生推荐信
2013/11/11 职场文书
卫生院健康教育实施方案
2014/06/07 职场文书
活动总结格式
2014/08/30 职场文书
没有孩子的离婚协议书怎么写
2014/09/17 职场文书
2014乡镇领导班子四风对照检查材料思想汇报
2014/10/05 职场文书
2014幼儿园大班工作总结
2014/11/10 职场文书
CSS3 制作的书本翻页特效
2021/04/13 HTML / CSS