百度在线人脸识别API简单实现

基于 Python2.7 ,百度人脸识别在线API的调用

1、申请百度人脸识别应用

首先需要在百度智能云平台登录,登陆后创建应用,创建的应用是人脸识别的,默认已帮你勾选上了相关功能。

创建应用后,点击管理应用,你就可以获取 API KeySecret Key

2、获取token

现在就可以编写代码调用在线的 人脸检测API

首先是获取 token ,用于校验,代码如下,注意换成自己申请的 API KeySecret Key

def getToken():
    global token
    # client_id 为官网获取的AK, client_secret 为官网获取的SK
    host = 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=你的API Key & client_secret=你的Secret Key'
    request = urllib2.Request(host)
    request.add_header('Content-Type', 'application/json; charset=UTF-8')
    response = urllib2.urlopen(request)
    content = response.read()
    if (content):
        token=json.loads(content)['access_token']

3、图片的base64编码

上传的用于检测的图片需经过 Base64编码。需要注意的是,图片的base64编码是不包含图片头的,代码如下:

def imgToBase64(imgPath):
    with open(imgPath, "rb") as f:  # 转为二进制格式
        base64_data = base64.b64encode(f.read())  # 使用base64进行加密
        return base64_data

4、人脸识别

调用接口进行人脸识别,代码如下:

def faceDetect(imgBase64):
    '''
    人脸检测与属性分析
    '''
    request_url = "https://aip.baidubce.com/rest/2.0/face/v3/detect"
    request_url = request_url + "?access_token=" + token
    request = urllib2.Request(request_url)
    request.add_header('Content-Type', 'application/json')
    data = {"image": imgBase64, "image_type": "BASE64","face_field":"age,beauty,expression,face_shape,gender"}
    response = urllib2.urlopen(request, urllib.urlencode(data))
    content = response.read()
    if content:
        return content

这个函数中输入的是图片的base64编码,请求的参数中比较重要的是那个face_field,默认只返回人脸框的位置、概率和旋转角度,age(年龄预测),beauty(颜值打分),expression(表情)等更多属性,需要在这个参数中添加,具体的请参考官方说明文档

5、结果绘制与可视化

人脸识别最后返回的是json数据,但我们往往需要画个框框,把人脸框出来,同时把一些预测的属性也标注上。

6、源代码

#coding:utf-8
import urllib,urllib2, sys
import ssl
import json
import base64
import cv2
global token
 
def getToken():
    global token
    # client_id 为官网获取的AK, client_secret 为官网获取的SK
    host = 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=你的API Key&client_secret=你的Secret Key'
    request = urllib2.Request(host)
    request.add_header('Content-Type', 'application/json; charset=UTF-8')
    response = urllib2.urlopen(request)
    content = response.read()
    if (content):
        token=json.loads(content)['access_token']
 
def faceDetect(imgBase64):
    '''
    人脸检测与属性分析
    '''
    request_url = "https://aip.baidubce.com/rest/2.0/face/v3/detect"
    request_url = request_url + "?access_token=" + token
    request = urllib2.Request(request_url)
    request.add_header('Content-Type', 'application/json')
    data = {"image": imgBase64, "image_type": "BASE64","face_field":"age,beauty,expression,face_shape,gender"}
    response = urllib2.urlopen(request, urllib.urlencode(data))
    content = response.read()
    if content:
        return content
 
def imgToBase64(imgPath):
    with open(imgPath, "rb") as f:  # 转为二进制格式
        base64_data = base64.b64encode(f.read())  # 使用base64进行加密
        return base64_data
 
 
if __name__=="__main__":
 
    getToken()
    imgPath=r"C:\Users\lee\Pictures\lena.jpg"
    result=json.loads(faceDetect(imgToBase64(imgPath)))['result']
    face_list=result['face_list'][0]
    location=face_list['location']
    age=face_list['age']
    beauty=face_list['beauty']
    expression=face_list['expression']['type']
    gender=face_list['gender']['type']
 
    img = cv2.imread(imgPath, cv2.IMREAD_COLOR)
    leftTopX=int(location['left'])
    leftTopY=int(location['top'])
    rightBottomX=int(leftTopX+int(location['width']))
    rightBottomY = int(leftTopY + int(location['height']))
    cv2.rectangle(img, (leftTopX, leftTopY), (rightBottomX, rightBottomY), (0, 255, 0), 2)
    font = cv2.FONT_HERSHEY_SIMPLEX
    # 第一个坐标表示起始位置
    cv2.putText(img,"age:"+str(age),(0, 20),font, 0.5, (200, 255, 255), 1)
    cv2.putText(img, "gender:" + gender.encode("utf-8"), (0, 40), font, 0.5, (200, 255, 255), 1)
    cv2.putText(img, "beauty:" + str(beauty), (0, 60), font, 0.5, (200, 255, 255), 1)
    cv2.putText(img, "expression:" + str(expression), (0, 80), font, 0.5, (200, 255, 255), 1)
    cv2.imshow('image', img)
    cv2.waitKey(0)
 
    print("end")
### 回答1: 人脸识别是通过计算机视觉和人工智能技术识别和分析人脸图像,进而实现人脸检测、人脸比对、人脸验证等功能。而百度提供的人脸识别API可以帮助我们快速、准确地实现人脸相关的功能。 要使用百度API进行人脸识别,首先需要在百度AI平台上注册账号并创建应用。在创建应用的过程中,会获得一个API Key和Secret Key,这两个密钥在我们的代码中起到了身份认证的作用。 使用Python调用百度API的步骤如下: 1. 安装必要的Python模块:在终端中使用pip命令安装需要的模块,如requests、base64等。 2. 导入所需的模块:在代码的开头导入需要使用的Python模块,如requests、base64等。 3. 设置API Key和Secret Key:将获得的API Key和Secret Key分别赋值给两个变量。 4. 读取待识别的人脸图像:使用Python的文件操作函数读取待识别的人脸图像文件,可以使用PIL等图像处理库对图像进行预处理。 5. 将图像转换为base64编码:使用base64等编码工具将人脸图像转换为base64编码的字符串。 6. 构建请求参数:将API Key、Secret Key和base64编码的人脸图像作为参数传递给API,并设置一些可选参数,如人脸识别的功能和阈值等。 7. 发送请求并获取结果:使用Python的请求库发送HTTP POST请求,并接收返回的结果。 8. 解析结果:对返回的结果进行解析,提取出需要的信息,如人脸的位置、特征等。 9. 处理结果:根据解析的结果进行相应的处理,如展示人脸图像、打印人脸信息等。 以上就是使用百度API进行人脸识别的基本步骤。当然,在实际应用中,还可以根据具体需求对结果进行进一步的处理和分析,例如人脸情绪分析、人脸属性检测等。 ### 回答2: 人脸识别是一种通过计算机技术来识别人脸的方法,而百度API提供了一种简单方便的方式来实现人脸识别。下面是使用百度APIPython代码进行人脸识别的示例: 首先,我们需要通过百度云控制台的人脸识别服务创建一个应用,并获取到API Key和Secret Key。 接下来,我们可以使用Python中的`requests`库来进行HTTP请求。首先,我们需要导入相应的库和模块: ```python import requests import base64 ``` 然后,我们需要定义获取API token的函数: ```python def get_access_token(api_key, secret_key): url = 'https://aip.baidubce.com/oauth/2.0/token' data = { 'grant_type': 'client_credentials', 'client_id': api_key, 'client_secret': secret_key } response = requests.post(url, data=data) access_token = response.json()['access_token'] return access_token ``` 接下来,我们可以定义一个函数来进行人脸识别: ```python def face_detection(api_key, secret_key, image_path): access_token = get_access_token(api_key, secret_key) url = 'https://aip.baidubce.com/rest/2.0/face/v3/detect' headers = { 'Content-Type': 'application/json' } with open(image_path, 'rb') as f: image = base64.b64encode(f.read()).decode('utf-8') data = { 'image': image, 'image_type': 'BASE64', 'face_field': 'age,gender,beauty', 'max_face_num': 10 } params = { 'access_token': access_token } response = requests.post(url, headers=headers, params=params, json=data) result = response.json() return result ``` 最后,我们可以调用上述函数来进行人脸识别,传入对应的API Key、Secret Key和人脸图片路径: ```python api_key = 'your_api_key' secret_key = 'your_secret_key' image_path = 'your_image_path' result = face_detection(api_key, secret_key, image_path) print(result) ``` 通过以上代码,我们可以使用百度APIPython来进行人脸识别。当然,以上代码只是简单的示例,具体的人脸识别功能还可以通过API的其他参数进行更多的设置和修改。 ### 回答3: 人脸识别是一种通过计算机技术识别和验证人脸特征的方法。百度提供了一系列人脸识别API,可以通过Python代码使用这些API。 首先,需要在百度AI开放平台上注册账号,并创建一个应用,获取API Key和Secret Key。 接下来,安装百度AI SDK包。在Python中,可以使用pip来安装: ``` pip install baidu-aip ``` 导入baidu-aip包,并初始化AipFace对象: ```python from aip import AipFace # 设置APPID/AK/SK APP_ID = 'your_app_id' API_KEY = 'your_api_key' SECRET_KEY = 'your_secret_key' client = AipFace(APP_ID, API_KEY, SECRET_KEY) ``` 接下来,可以使用AipFace对象调用百度API人脸识别功能。以下是一个简单的人脸检测代码示例: ```python import base64 # 读取图片并进行Base64编码 with open("face.jpg", "rb") as f: image = base64.b64encode(f.read()).decode("utf-8") # 调用人脸检测API result = client.detect(image, 'BASE64') # 解析结果 if 'result' in result: face_num = result['result']['face_num'] face_list = result['result']['face_list'] for face in face_list: face_location = face['location'] left = face_location['left'] top = face_location['top'] width = face_location['width'] height = face_location['height'] print(f"人脸位置:left={left}, top={top}, width={width}, height={height}") else: print("人脸检测失败") ``` 以上是一个简单的人脸检测的例子,可以通过修改参数和调用其他API实现不同的人脸识别功能,如人脸对比、人脸搜索等。 通过百度APIPython代码,我们可以快速实现人脸识别的功能,方便地应用于各种项目和应用场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值