python人脸识别库_基于Python的face_recognition库实现人脸识别
Python
Python开发
Python语言
基于Python的face_recognition库实现人脸识别
一、face_recognition库简介
face_recognition是Python的一个开源人脸识别库,支持Python 3.3+和Python 2.7。引用官网介绍:
Recognize and manipulate faces from Python or from the command line with the world's simplest face recognition library.
之所以选用这个库,是因为
1、用这个库来实现一个人脸识别程序非常简单,环境配置也很容易;
2、可以直接使用已经训练好的模型,不需要在本地重新训练。一般普通的电脑都可以直接运行识别程序,硬件环境要求不高。
PS:很多人在学习Python的过程中,往往因为遇问题解决不了或者没好的教程从而导致自己放弃,为此我整理啦从基础的python脚本到web开发、爬虫、django、数据挖掘等【PDF等】需要的可以进Python全栈开发交流.裙 :一久武其而而流一思(数字的谐音)转换下可以找到了,里面有最新Python教程项目可拿,不懂的问题有老司机解决哦,一起相互监督共同进步
二、环境安装
我自己的环境如下:
硬件:08年的笔记本电脑,奔腾双核,算是比较低端的笔记本了
系统:win7x64
python:3.6 (注意:建议用3.6版本配置环境。我自己用3.7配置环境失败了,dlib安装总是失败。)
用3.6安装的过程比较简单,可以参考https://www.jianshu.com/p/8296f2aac1aa
用pip安装之前,注意首先修改pip为阿里的源,这样速度就快多了。
三、代码实现
import face_recognition
import cv2
import os
import numpy as np
from PIL import Image,ImageDraw,ImageFont
#路径参数配置
basefacefilespath = "0s" # faces文件夹中放待识别任务正面图,文件名为人名,将显示于结果中
destfacefilepath = "0d" #用于识别的目标图片目录
#写入中文字符支持
def paint_chinese_opencv(im, chinese, pos, color):
img_PIL = Image.fromarray(cv2.cvtColor(im, cv2.COLOR_BGR2RGB))
font = ImageFont.truetype('simsun.ttc', 14)
fillColor = color # (255,0,0)
position = pos # (100,100)
#chinese = chinese.decode('utf-8')
draw = ImageDraw.Draw(img_PIL)
draw.text(position, chinese, font=font, fill=fillColor)
img = cv2.cvtColor(np.asarray(img_PIL), cv2.COLOR_RGB2BGR)
return img
# 加载待识别人脸图像并识别。
baseface_titles = [] # 图片名字列表
baseface_face_encodings = [] # 识别所需人脸编码结构集
#读取人脸资源
for fn in os.listdir(basefacefilespath): #fn 人脸文件名
baseface_face_encodings.append(
face_recognition.face_encodings(face_recognition.load_image_file(basefacefilespath+"/"+fn))[0])
#fn = fn.split("_")[1]
fn = fn[:(len(fn) - 4)]
baseface_titles.append(fn)
print(fn)
#从识别库中读取一张图片并识别
for fd in os.listdir(destfacefilepath):
# 获取一张图片
faceData = face_recognition.load_image_file(destfacefilepath + "/" + fd)
print(fd)
# 人脸检测,并获取帧中所有人脸编码
face_locations = face_recognition.face_locations(faceData)
face_encodings = face_recognition.face_encodings(faceData, face_locations)
# 遍历图片中所有人脸编码
for (top, right, bottom, left), face_encoding in zip(face_locations, face_encodings):
# 与baseface_face_encodings匹配否?
name = "?"
for i,v in enumerate(baseface_face_encodings):
match = face_recognition.compare_faces([v], face_encoding,tolerance=0.5)
name = "?"
if match[0]:
name = baseface_titles[i]
print("识别出:" + name)
break
#如果遇到没有识别出的人脸,则跳过
if name == "?":
continue
# 围绕脸的框
cv2.rectangle(faceData, (left, top), (right, bottom), (0, 0, 255), 2)
# 框下的名字(即,匹配的图片文件名)
cv2.rectangle(faceData, (left, bottom), (right, bottom+25), (0, 0, 255), cv2.FILLED)
#faceData = cv2.putText(faceData, name,(left + 2, bottom + 12), cv2.FONT_HERSHEY_SIMPLEX,0.5, (255, 255, 255),1)
faceData = paint_chinese_opencv(faceData, name, (left + 2, bottom + 4), (255, 255, 255))
# frame = ft.draw_text(frame, (left + 2, bottom + 12), name, 16, (255, 255, 255))
# show结果图像
cv2.imshow(fd, cv2.cvtColor(faceData, cv2.COLOR_BGR2RGB))
cv2.waitKey()
cv2.destroyAllWindows()
图片分为两个文件夹:0s和0d
0s中存放的是基础人脸数据
0d文件夹中存放的是接下来要进行识别的图片,我这里放了3张:
四、运行效果
运行结果:
五、问题总结
1、cv2.imshow,这个最开始显示的图片颜色不对,后来修改如下:
cv2.imshow(fd, cv2.cvtColor(faceData, cv2.COLOR_BGR2RGB))
将图片的颜色模式调整为RGB,然后色彩就正常了。
2、中文字符支持,最开始用 cv2.putText,但是这个函数只支持英文字符,中文字符会显示问号乱码。
后加入中文字符支持函数,用 PIL 库中的 ImageDraw 来写入中文字符。
总结:很多人在学习Python的过程中,往往因为遇问题解决不了或者没好的教程从而导致自己放弃,为此我整理啦从基础的python脚本到web开发、爬虫、django、数据挖掘等【PDF等】需要的可以进Python全栈开发交流.裙 :一久武其而而流一思(数字的谐音)转换下可以找到了,里面有最新Python教程项目可拿,不懂的问题有老司机解决哦,一起相互监督共同进步
本文的文字及图片来源于网络加上自己的想法,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理。
内容来源于网络,如有侵权请联系客服删除
python人脸识别库_基于Python的face_recognition库实现人脸识别相关推荐
- python dlib opencv人脸识别准确度_基于dlib和opencv库的人脸识别
基于dlib和opencv库的人脸识别 需下载68个特征点的人脸检测模型: http://dlib.net/files/ 文件名为shape_predictor_68_face_landmarks.d ...
- python开发语音录入_基于python实现语音录入识别代码实例
这篇文章主要介绍了如何通过python实现语音录入识别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一.介绍 1.第一步录音存入本地 2.调用百度 ...
- python实现ocr识别算法_基于Python的OCR实现示例
摘要: 近几天在做一个东西,其中需要对图像中的文字进行识别,看了前辈们的文章,找到两个较简单的方法:使用python的pytesseract库和调用百度AI平台接口.写下这篇文章做一个比较简短的记录和 ...
- autocad python二次开发_基于Python AutoCAD ActiveX 二次开发,pyautocad应用技术
AutoCAD应用程序开发系列 基于Python AutoCAD ActiveX 二次开发技术 主要库:pyautocad==0.2.0 内容#:基于Python AutoCAD ActiveX 二次 ...
- 用python做炒股软件-python程序源码_基于python的炒股软件
股票模拟交易系统设计与实现 不但能够进行界面的设计,还可以实现各个窗口的关联,通过WPF实现和其余窗口的关联,而且WPF中的类不但能够和其中一个窗口进行关联,还可以跟许多功能操作接口,WPF在对窗口对 ...
- python安装pyecharts清华_基于Python安装pyecharts所遇的问题及解决方法
最近学习到数据可视化内容,老师推荐安装pyecharts,于是pip install 了一下,结果...掉坑了,下面是我的跳坑经验,如果你有类似问题,希望对你有所帮助. 第一个坑: 这个不难理解,缺少 ...
- python实现实时监控_基于 Python 的交换机实时监控系统的设计与实现
从高校校园网运维工作实际出发,论文提出了一种基于 Python 语言+SNMP协议的网络交换机监测系统设计思路与实现方法.整个系统系统采用B/S模式,基于轻量级的web开发框架web.py实现.后端采 ...
- python生成json接口_基于python的Flask框架写json接口并且结合eolinker进行接口测试
一.前言 很多时候为了提高软件开发的效率,后端程序人员理想状态下应该编写程序测试接口供前端程序人员进行测试,以便前端的开发.笔者由于项目的需求近期尝试学习了一下测试接口的编写,以Python+Flas ...
- python音频实时频谱分析_基于python的音频设计及频谱分析
74 Internet Technology 互联网 + 技术 一.引言 WAV 是 Microsoft 开发的一种声音文件格式,虽然它支持多种压缩格式,但是它通常被用来保存未压缩的声音数据(PCM ...
最新文章
- 180904 再卖菜 ccf
- c++STL容器的Map和multimap
- UINavigationController的简单使用
- CTO 离职、研发变动,百度外卖与饿了么组织架构融合公布
- VBA代码执行过程中,显示程序的运行状态
- [转载] java 中 date类型详解
- 使用jvisualvm通过JMX的方式监控远程JVM运行状况
- linux查看网卡带宽命令,Linux查看网卡带宽的两个命令
- 比特彗星(Bitcomet_1.95)最新官方安装包下载
- 微信的Linux版本,ubuntu16.04安装微信,linux原生版
- ThinkPHP整合微信支付之发裂变红包
- 打造高效研发团队 (3) —— 绩效考核篇
- 网易微专业Android实战教程
- WPF实现炫酷Loading控件
- Dextran-PEG2000-Conjugate,葡聚糖聚乙二醇Conjugate,葡聚糖聚乙二醇,属于葡聚糖缀合物
- Java - 谷歌邮箱发送邮件详解
- 如果计算机电源突然断电 会导致,电脑突然断电问题
- BAPC 2019 G. Gluttonous Goop 线段树扫描线
- 电子信息技术专业名词中英文对照(一)
- 《A diagonal quasi-Newton updating method for unconstrained optimization》文献算法实现