实现人脸截图保存并编写128维特征向量

简介: ## 前情提要通过[上一篇](https://developer.aliyun.com/article/868130?spm=a2c6h.26396819.0.0.6e513e18zineFN)我们就可以对图片中的人脸进行识别,这篇文章就来教大家怎么对人脸部分进行截取保存。并且将图片中的每张人脸编码成一个128维长度的向量,通过这个后续能在人脸之间进行比对。

前情提要

通过上一篇我们就可以对图片中的人脸进行识别,这篇文章就来教大家怎么对人脸部分进行截取保存。并且将图片中的每张人脸编码成一个128维长度的向量,通过这个后续能在人脸之间进行比对。

PIL导入

由于我们需要进行切割和保存所有我这里使用了PIL库进行,Python图像库PIL(Python Image Library)是python的第三方图像处理库,但是由于其强大的功能与众多的使用人数,几乎已经被认为是python官方图像处理库了。其官方主页为:PIL。 PIL历史悠久,原来是只支持python2.x的版本的,后来出现了移植到python3的库pillow,pillow号称是friendly fork for PIL,其功能和PIL差不多,但是支持python3。conda环境中只需activate "你所使用的环境" 然后 conda install pillow 即可,python默认环境中只需pip install pillow ,或是都可通过pycharm搜索pillow进行下载

人脸编码函数——face_encodings

face_encodings( face_image , known_face_locations=None , num_jitters=1 ) 给定一个图像,返回图像中每个人脸的128脸部编码(特征向量)。 参数: face_image : 输入的人脸图像 known_face_locations : 可选参数,如果你知道每个人脸所在的边界框 num_jitters=1 : 在计算编码时要重新采样的次数。越高越准确,但速度越慢(100就会慢100倍)
返回值: 一个128维的脸部编码列表,返回值类型为:List[Dict[str,List[Tuple[Any,Any]]]],是由各个脸部特征关键点位置组成的字典记录 列表,一个Dict对象对应图片中的一个人脸,其key为某个脸部特征: 如输出中的nose_bridge、left_eye等,value是由该脸部特征各个关键点位置组成的List,关键点位置是一个Tuple。

切割

而我们想要对人脸部分实现截图保存只需要通过上篇文章中face_locations函数定位到人脸部分时进行切割即可我用到的是Image.crop()方法进行切割。具体代码如下(有详细解释,嘿嘿)

具体代码

Main

import face_recognition
from PIL import Image
import Test3                  # 导入Test3

'''
图片中人脸截图保存
'''
img = Image.open("2.png")
image = face_recognition.load_image_file("2.png")
face_locations = face_recognition.face_locations(image)  # 参数(top, right, bottom, left) 上右角 下左角
for i in range(len(face_locations)):
    top, right, bottom, left = face_locations[i]
    region = img.crop((left, top, right, bottom))  # 参数(left, upper, right, lower)  左上角  右下角 进行切割
    region.save(str(i)+"_.jpg") # 保存 
    region.show()     # 展示
    Test3.demoFunc("2.png")   #  调用Test3中的demoFunc()方法

Test3

import face_recognition

def demoFunc(path):
  '''
    将图片中的每张人脸编码成一个128维长度的向量
    '''
    image = face_recognition.load_image_file(path)
    face_encodings = face_recognition.face_encodings(image)  #将单个人脸数据转化为一个128维的向量
    for i in face_encodings:
        print("i:", i)

结果展示

又到了激动人心的展示时刻了
128维向量
嘿嘿大头照

总结

人脸识别第二期结束,如果大家觉得还不错有所帮助的话可以点点小赞哈哈,大家一起努力进步!

目录
相关文章
|
Shell Linux 计算机视觉
【Dlib】动作检测:以常见的人脸识别验证为例讲解张嘴与闭眼
【Dlib】动作检测:以常见的人脸识别验证为例讲解张嘴与闭眼
767 0
|
6月前
|
开发者
《HarmonyOSNext自动续期订阅支付全攻略 | 从环境检测到防漏单指南》
本文详解HarmonyOS Next自动续期订阅支付全流程,涵盖环境检测、商品展示、订单处理与防漏单策略,适用于教育科普行业开发者学习参考。
148 5
|
8月前
|
域名解析 存储 网络协议
域名解析的终极指南:从基础到进阶,彻底搞懂 DNS 记录
域名解析是网站运行的基础,正确配置DNS记录至关重要。本文从基础到进阶全面解析DNS知识,涵盖A、AAAA、CNAME、MX、TXT、CAA等常见记录类型及其应用场景。通过学习,你将了解DNS的工作原理,掌握如何优化域名配置,确保网站与邮件服务高效运行。无论搭建个人博客还是企业官网,本文都能助你轻松搞定域名解析!
1834 0
|
5月前
|
机器学习/深度学习 自动驾驶 算法
基于深度学习的YOLO框架的7种交通场景识别项目系统【附完整源码+数据集】
在智慧交通和智能驾驶日益普及的今天,准确识别复杂交通场景中的关键元素已成为自动驾驶系统的核心能力之一。传统的图像处理技术难以适应高动态、复杂天气、多目标密集的交通环境,而基于深度学习的目标检测算法,尤其是YOLO(You Only Look Once)系列,因其检测速度快、精度高、可部署性强等特点,在交通场景识别中占据了重要地位。
660 0
基于深度学习的YOLO框架的7种交通场景识别项目系统【附完整源码+数据集】
|
人工智能 API 开发工具
YOLOV11 使用流程
本内容整理了YOLO V11的常用代码语句,涵盖YOLO模型下载、数据集划分、模型训练与推理优化等关键步骤,适用于目标检测任务。
|
9月前
|
监控 数据可视化 前端开发
17.8K star!完美超越宝塔的产品,像呼吸一样部署应用,这款开源神器绝了!
Dokploy是一个强大的开源平台,旨在简化全栈 Web 应用的开发和部署。通过其直观的界面和丰富的功能,开发者可以在几分钟内构建和部署复杂的应用程序。Dokploy 提供了灵活的架构和多样的功能,适合各种规模的项目。
492 3
|
SQL 关系型数据库 MySQL
解决:Mybatis-plus向数据库插入数据的时候 报You have an error in your SQL syntax
该博客文章讨论了在使用Mybatis-Plus向数据库插入数据时遇到的一个常见问题:SQL语法错误。作者发现错误是由于数据库字段中使用了MySQL的关键字,导致SQL语句执行失败。解决方法是将这些关键字替换为其他字段名称,以避免语法错误。文章通过截图展示了具体的操作步骤。
|
机器学习/深度学习 人工智能 监控
人脸识别技术发展历史、技术全解和实战应用
人脸识别技术发展历史、技术全解和实战应用
760 1
|
传感器 人工智能 前端开发
JAVA语言VUE2+Spring boot+MySQL开发的智慧校园系统源码(电子班牌可人脸识别)Saas 模式
智慧校园电子班牌,坐落于班级的门口,适合于各类型学校的场景应用,班级学校日常内容更新可由班级自行管理,也可由学校统一管理。让我们一起看看,电子班牌有哪些功能呢?
776 4
JAVA语言VUE2+Spring boot+MySQL开发的智慧校园系统源码(电子班牌可人脸识别)Saas 模式