python如何识别中文_中文情绪识别api

前言

国庆的时候用LSTM搭建的了一个神经网络,训练微博数据集来进行情感多分类。后来觉得之前那个数据集不太行,所以经过大量的资料搜索,使用了当前这个数据集。数据集的提供方是清华大学计算机系黄民烈副教授。共4万多条句子,分为其他(Null), 喜好(Like),悲伤(Sad),厌恶(Disgust),愤怒(Anger),高兴(Happiness)六类。相对之前那个数据集更具权威性和准确性。

通过Django部署keras模型

重新训练模型后,我就想把它用在之前的web项目中。开始想的是直接用java调用python程序,试了试,效果不太理想。然后就硬着头皮学了一下Django框架,挺好上手的,看了下官方文档,就搭了个demo,把预测程序放进去用了。但是还是遇到了一些坑,在此记录一下吧。

坑1——Django下的文件路径问题

因为第一次接触Django,很多问题也不太懂。开始以为加载文件就是类似加载静态文件就行了,然而我错了,它根本不能被认出来。然后只能把它当做外部文件来加载。解决方法如下:

将文件保存在django项目根目录中,并在settings.py文件中添加以下内容.

PROJECT_ROOT = os.path.abspath(os.path.dirname(__file__))1

然后在打开文件时加一些操作,这里就是在文件名前添加了项目的根路径。

import os

from django.conf import settings

model = load_model(os.path.join(settings.BASE_DIR, 'my_model.h5'))1

2

3

坑2——版本问题

由于之前使用的是keras3.0,然后Keras 2.3.0中添加了线程本地存储元素。在调用模型时(例如,从批处理生成器中),将引发与线程本地数据相关的属性错误。然后被迫降低版本为Keras2.2.4,但是降了keras版本后又导致TensorFlow出问题了(我的TensorFlow是2.0.0版本),mmp,版本又不兼容。然后又降低TensorFlow版本为1.14.0。emmm,程序跑起来了,有点小激动。

坑3——多线程下的变量问题

开始测试调用api,第一次,么得问题,好开心,第二次,程序崩了。啥子问题?emmm,因为Django是多线程运行的,但是我的模型是直接加载的,所以导致多线程运行环境中全局不唯一。最后是通过tf.get_default_graph()来将加载的模型作为这个TensorFlow运行环境的默认图,也就是唯一的图啦,然后程序就可以快活的跑起来啦。部分代码如下:

# 加载模型,并使模型和变量在同一图内

global graph

model = load_model(os.path.join(settings.BASE_DIR, 'my_model.h5'))

graph = tf.get_default_graph()1

2

3

4

说了这么多,大家想不想玩一下呢,啊哈哈哈。

GitHub地址: sentiment_analysis_api 如果觉得有点意思,请给个小星星哦。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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、付费专栏及课程。

余额充值