@Author: Runsen
本项目围绕图像识别,通过调用百度 API 接口,可以实现很多人性化的功能,比如手势识别、比对、人像分割以及颜值打分等功能。
本项目结合人工智能和GUI图形界面开发,满足用户对图像识别方面的需求。
在本次项目中主要使用的技术点:
- 百度API接口调用
- Tkinker
- opencv调用USB摄像头
文章目录
- 功能需求
- 获取access token值
- 颜值进行评分
- 手势识别
- 人像分割抠图
- 完整代码
功能需求
本次 Python 小项目主要功能:调用电脑摄像头实现拍照,并使用百度 API 接口实现颜值评分,手势识别和抠图。
功能需求的API文档:
颜值评分:https://ai.baidu.com/ai-doc/FACE/yk37c1u4t
手势识别:https://ai.baidu.com/ai-doc/BODY/4k3cpywrv
人像分割:https://ai.baidu.com/ai-doc/BODY/Fk3cpyxua
功能 | 实现流程 | 接口API |
颜值评分(face_detect) | 调用摄像头进行拍照识别,识别结果包括年龄,性别,人种,颜值评分 | https://aip.baidubce.com/rest/2.0/face/v3/detect |
手势识别(gesture) | 调用摄像头进行拍照识别,识别结果为手势的中文大意和英文大意 | https://aip.baidubce.com/rest/2.0/image-classify/v1/gesture |
人像分割(body_seg) | 调用摄像头进行拍照识别,对人物进行抠图 | https://aip.baidubce.com/rest/2.0/image-classify/v1/body_seg |
获取access token值
本次项目采用封装类的方法进行代码编写,需要对Baidu_API封装成类。
颜值进行评分
识别结果包括年龄,性别,人种,颜值评分(0-100)
上面图片返回的结果:47.34 22 male yellow
手势识别
识别结果包括手势的中文大意和英文大意
上面图片返回的结果:Five 五个
人像分割抠图
返回的结果是对人物进行抠图
完整代码
'''
@Author: Runsen
@Date: 2020/11/29
'''
import requests
import base64
class Baidu_API():
def __init__(self):
self.headers={'Content-Type': 'application/json; charset=UTF-8'}
self.AppID = '23061934' # 百度应用账号ID
self.APIKey = '0EGiM1wDAH5kmFAvhYVLYCbs' # 针对接口访问的授权方式
self.SecretKey = 'KVugHxxu4uq203b111SwVY2w98Cd9D70' # 密钥
#获取access token值
def get_access_token(self):
host = 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id={}&client_secret={}'.format(self.APIKey,self.SecretKey)
response = requests.get(host,self.headers)
if response:
access_token=response.json()['access_token']
return access_token
else:
print("access_token获取失败")
#获取转换图片格式为base64的图片数据
def get_img_base64(self,img_path):
# 先以二进制的格式读取图片,再转化为base64格式(使用二进制转base64格式的函数)
with open(img_path,'rb')as f:
# base64编码
img_data = base64.b64encode(f.read())
return img_data
#功能1、对颜值进行评分
def face_detect(self,img_path):
try:
# 访问人脸检测api
base_url = "https://aip.baidubce.com/rest/2.0/face/v3/detect"
# 基本参数
request_url = base_url + "?access_token=" + self.get_access_token()
params = {"image": self.get_img_base64(img_path),
"image_type": "BASE64",
"face_field": "faceshape,facetype,beauty,age,beauty,glasses,gender,race"}
# 开始访问
response = requests.post(url=request_url,
data=params,
headers=self.headers)
re = response.json()
score = re["result"]["face_list"][0]['beauty']
age = re["result"]["face_list"][0]['age']
gender = re["result"]["face_list"][0]['gender']['type']
race = re["result"]["face_list"][0]['race']['type']
# 返回数据
print(score,age,gender,race)
return score,age,gender,race
except:
return '未能正确识别,请重试'
#功能2、手势识别
def gesture(self,img_path):
try:
base_url = 'https://aip.baidubce.com/rest/2.0/image-classify/v1/gesture'
# 基本参数
request_url = base_url + "?access_token=" + self.get_access_token()
params = {"image": self.get_img_base64(img_path),
"image_type": "BASE64"}
# 开始访问
response = requests.post(url=request_url,
data=params,
headers=self.headers) # <class 'requests.models.Response'>
re = response.json() # <class 'dict'>
classname_en = re["result"][0]['classname']
classname_zh = self.translate(classname_en)
print(classname_en,classname_zh)
return classname_en,classname_zh
except:
return '未能正确是识别,请重试'
#功能3、人像分割抠图
def body_seg(self,img_path, out_path):
try:
base_url = "https://aip.baidubce.com/rest/2.0/image-classify/v1/body_seg"
request_url = base_url + "?access_token=" + self.get_access_token()
params = {"image": self.get_img_base64(img_path)}
headers = {'content-type': 'application/x-www-form-urlencoded'}
response = requests.post(request_url, data=params, headers=headers)
labelmap = base64.b64decode(response.json()['foreground'])
with open(out_path, 'wb') as fp:
fp.write(labelmap)
except:
return '未能正确识别,请重试'
# 翻译APi接口
def translate(self, query):
url = 'http://fanyi.youdao.com/translate?&doctype=json&type=AUTO&i={}'.format(query)
r = requests.post(url=url)
return r.json()['translateResult'][0][0]['tgt'].strip('的')
if __name__ == '__main__':
Api = Baidu_API()
Api.face_detect('me.jpg')
Api.gesture('gesture.jpg')
Api.body_seg('me.jpg','me.png')