人脸识别分析小Demo
人脸识别分析
调用
腾讯AI人脸识别接口
测试应用
纯py文件测试照片
# -*- coding: utf-8 -*-
import json from tencentcloud.common import credential
from tencentcloud.common.exception.tencent_cloud_sdk_exception import TencentCloudSDKException
# 导入对应产品模块的 client models。
from tencentcloud.common.profile.client_profile import ClientProfile
from tencentcloud.iai.v20180301 import iai_client, models
import base64 def get_json(img_dir):
with open(img_dir, 'rb') as f:
base64_data = base64.b64encode(f.read())
base64_code = base64_data.decode()
try:
# 实例化一个客户端配置对象,可以指定超时时间等配置
clientProfile = ClientProfile()
clientProfile.signMethod = "TC3-HMAC-SHA256" # 指定签名算法
# 实例化一个认证对象,入参需要传入腾讯云账户 secretId,secretKey
cred = credential.Credential(secretId, secretKey)
client = iai_client.IaiClient(cred, "ap-guangzhou", clientProfile)
# 实例化一个请求对象
req = models.DetectFaceRequest() # 人脸检测参数
req.MaxFaceNum = 1
req.Image = base64_code
req.NeedFaceAttributes = 1
req.NeedQualityDetection = 0 # 通过 client 对象调用想要访问的接口,需要传入请求对象
resp = client.DetectFace(req)
# 输出 JSON 格式的字符串回包
json_data = resp.to_json_string() return json_data except TencentCloudSDKException as err:
print(err)
return None secretId = '你的id'
secretKey = '你的key'
img_dir = "img\dlrb.jpg"
json_data = get_json(img_dir)
data=json.loads(json_data) data2=data["FaceInfos"]
data2=str(data2)
data3=data2[1:-1].replace("'", "\"").replace("False","\"False\"").replace("True","\"True\"") data4=json.loads(data3) face=data4["FaceAttributesInfo"]
people={}
if face["Gender"]>50:
people["Gender"]="男性"
else:
people["Gender"]="女性"
people["Age"]=face["Age"]
if face["Expression"]>50:
people["smile"]="大笑"
else:
people["smile"]="微笑"
if face["Glass"]=="False":
people["Glass"]="未戴眼镜"
else:
people["Glass"]="戴眼镜"
people["Beauty"]=face["Beauty"]
if face["Hat"]=="False":
people["Hat"]="未戴帽子"
else:
people["Hat"]="戴帽子"
if face["Mask"]=="False":
people["Mask"]="未戴口罩"
else:
people["Mask"]="戴口罩"
hair=face["Hair"] str="" if hair["Bang"]==0:
str="有刘海"
else:
str="无刘海" if hair["Color"]==0:
str=str+"黑色"
elif hair["Color"]==1:
str=str+"金色"
elif hair["Color"]==2:
str=str+"棕色"
elif hair["Color"]==3:
str=str+"灰白色" if hair["Length"]==0:
str=str+"光头"
elif hair["Length"]==1:
str=str+"短发"
elif hair["Length"]==2:
str=str+"中发"
elif hair["Length"]==3:
str=str+"长发"
elif hair["Length"] == 4:
str=str+"绑发" people["Hair"]=str if face["EyeOpen"]=="True":
people["EyeOpen"]="睁着眼"
else:
people["EyeOpen"] = "闭着眼" print(data)
print(people)
输出结果:
实例应用-web界面上传照片后可进行人来你分析
界面展示
操作步骤
用户上传小于3M的照片后,进行智能判断即可分析人脸的属性
代码流程
①写个界面,包含图片上传以及属性input表格
②进行后端照片的存储,存储到本地,并将图片路径返回到界面,存储在一个hidden标签内
③当用户点击“智能判断”后,将图片路径返回后端,后端通过上面的纯py代码进行分析,将结果返回,然后呈现到界面上
实际测试
找了几个舍友和张一凡还有鞠婧祎进行测试
鞠婧祎:
张一凡:
人脸识别分析小Demo的更多相关文章
- 人脸识别ArcFace C#DEMO 开发应用全过程
手上有一个项目,需要检验使用本程序的,是否本人!因为在程序使用前,我们都已经做过头像现场采集,所以源头呢是不成问题的,那么人脸检测,人脸比对,怎么办呢?度娘了下,目前流行的几个人脸检测,人脸比对核心, ...
- 虹软人脸识别——官方 Qt Demo 移植到 Linux
一.前言 最近需要在 Linux 平台下开发一个人脸识别相关的应用,用到了虹软的人脸识别 SDK.之前在 Windows 平台用过,感觉不错,SDK 里面还带了 Demo 可以快速看到效果.打开 Li ...
- 基于Arcface 免费离线人脸识别 2.0 Demo C#
本来打算做个C#版demo,但没用成功.使用虹软最新人脸识别技术开发完成 过程如下: 1. 传入一张单人脸照片: 2.调用检测人脸函数ASFDetectFaces,成功返回人脸信息的指针: 3.使用 ...
- 人脸识别最新开发经验demo分享
本来打算做个C#版demo,但没用成功,基于虹软的免费人脸识别技术 过程如下: 1. 传入一张单人脸照片: 2.调用检测人脸函数ASFDetectFaces,成功返回人脸信息的指针: 3.使用 Mar ...
- Android静态图片人脸识别的完整demo(附完整源码)
Demo功能:利用android自带的人脸识别进行识别,标记出眼睛和人脸位置.点击按键后进行人脸识别,完毕后显示到imageview上. 第一部分:布局文件activity_main.xml < ...
- C# ArcFace 免费人脸识别 2.0 demo
**配置过程:** 1. 到[虹软官网](https://ai.arcsoft.com.cn/index.htm?utm_source=csdn&utm_medium=referral)下载S ...
- 基于百度AI人脸识别技术的Demo
编写demo之前首先浏览官方API:http://ai.baidu.com/docs#/Face-API/top 下面是源码: package com.examsafety.test; import ...
- 人脸识别&ORC的Demo
一.用到的jar包: face_sdk-1.3.4.jar json-20160810.jar ocr_sdk-1.3.4.jar 下载地址:https://files.cnblogs.com/fil ...
- Android开发 打开已存在的项目(以虹软人脸识别sdk的demo为例)
详细流程参考博客https://blog.csdn.net/z979451341/article/details/79468785 个人遇到的问题与注意点 1.下载Demo后忘记修改appid和sdk ...
随机推荐
- poj1061青蛙的约会 (扩展欧几里德)
Description 两只青蛙在网上相识了,它们聊得很开心,于是觉得很有必要见一面.它们很高兴地发现它们住在同一条纬度线上,于是它们约定各自朝西跳,直到碰面为止.可是它们出发之前忘记了一件很重要的事 ...
- python的scrapy框架的使用 和xpath的使用 && scrapy中request和response的函数参数 && parse()函数运行机制
这篇博客主要是讲一下scrapy框架的使用,对于糗事百科爬取数据并未去专门处理 最后爬取的数据保存为json格式 一.先说一下pyharm怎么去看一些函数在源码中的代码实现 按着ctrl然后点击函数就 ...
- Strongly connected HDU - 4635 原图中在保证它不是强连通图最多添加几条边
1 //题意: 2 //给你一个有向图,如果这个图是一个强连通图那就直接输出-1 3 //否则,你就要找出来你最多能添加多少条边,在保证添加边之后的图依然不是一个强连通图的前提下 4 //然后输出你最 ...
- Codeforces Round #481 (Div. 3) G. Petya's Exams (贪心,模拟)
题意:你有\(n\)天的时间,这段时间中你有\(m\)长考试,\(s\)表示宣布考试的日期,\(d\)表示考试的时间,\(c\)表示需要准备时间,如果你不能准备好所有考试,输出\(-1\),否则输出你 ...
- bfs输出路径 && 最短路(迪杰斯特拉)输出路径
问题描述 解决方法 1.像第一个问题那就是最短路问题(我代码采用迪杰斯特拉算法)实现 2.换乘次数最少,那就用bfs广搜来寻找答案.但是我的代码不能保证这个最少换乘是最短路程 代码 1 #includ ...
- 二进制安装kubernetes(四) kube-scheduler组件安装
介绍资料转载地址:https://www.jianshu.com/p/c4c60ccda8d0 kube-scheduler在集群中的作用 kube-scheduler是以插件形式存在的组件,正因为以 ...
- 字节笔试题 leetcode 69. x 的平方根
更多精彩文章请关注公众号:TanLiuYi00 题目 解题思路 题目要求非负整数 x 的平方根,相当于求函数 y = √x 中 y 的值. 函数 y = √x 图像如下: 从上图中,可以看出函数是单 ...
- leetcode 36 有效的数独 哈希表 unordered_set unordersd_map 保存状态 leetcode 37 解数独
leetcode 36 感觉就是遍历. 保存好状态,就是各行各列还有各分区divide的情况 用数组做. 空间小时间大 class Solution { public: bool isValidSud ...
- leetcode17 电话号码的字母组合 dfs
就dfs吧.... 然后,我傻了.前一道题不用考虑空,这道题就要考虑.... 还有注意vector要引用传递 class Solution { public: void dfs(string temp ...
- HDU 6390 GuGuFishtion(莫比乌斯反演 + 欧拉函数性质 + 积性函数)题解
题意: 给定\(n,m,p\),求 \[\sum_{a=1}^n\sum_{b=1}^m\frac{\varphi(ab)}{\varphi(a)\varphi(b)}\mod p \] 思路: 由欧 ...