代码拉取完成,页面将自动刷新
# encoding=utf8
'''
接口主函数
主函数所在的服务器需提前进行端口映射(分别对应操作识别、知识图谱、意图识别、端到端):
【如果模块服务和主函数部署到同一台服务器的同一个容器中,则不需进行端口映射】
ssh -4 -N -f -p 2060 -L 5001:127.0.0.1:5001 cike@202.38.247.166
ssh -4 -N -f -p 2016 -L 5002:127.0.0.1:5000 cike@202.38.247.163
ssh -4 -N -f -p 2060 -L 5003:127.0.0.1:5003 cike@202.38.247.166
ssh -4 -N -f -p 2040 -L 5004:127.0.0.1:3000 cike@222.201.134.236
本地访问主函数接口需要进行接口映射:
ssh -p 2060 -L 5000:127.0.0.1:5000 cike@202.38.247.166
'''
import requests
from flask import Flask, request, jsonify
import ast
app = Flask(__name__)
def Str2Obj(string):
'''
将字符串转为python中的对象
:param string: 原字符串
:return: python对象/字符串
'''
try:
obj = ast.literal_eval(string)
return obj
except Exception as e:
return string
def FusionMethod1(End2End_res,IntentReg_res):
'''
融合方法1:进行模糊维度的融合,减少用户的选择量
:return: 用户待选择的维度
'''
# 获取sel维度name
sel = []
sel_name = []
End2End_data = End2End_res["data"]
for item in End2End_data:
if item["key"] == "sel":
sel = Str2Obj(item["content"])
break
for item in sel:
sel_name.append(item["name"])
temp_end2end = set(sel_name)
# 融合1——如果sel_name和每个待选择的维度列表存在交集并且交集元素为1,则该模糊维度不需要用户进行选择
for item in IntentReg_res["data"]:
candidates = Str2Obj(item["candidates"])
temp_intent = set(candidates)
intersection = temp_intent & temp_end2end
if len(intersection) == 1:
item["candidates"] = list(intersection)
return jsonify(IntentReg_res)
@app.route('/IntentRegEngine', methods=["POST"])
def IntentRegEngine():
# 接口url
OptReg_request_url = "http://localhost:5001/OptRecognition"
KB_request_url = "http://localhost:5002/index"
IntentReg_request_url = "http://localhost:5003/getSQLs_error"
End2End_request_url = "http://localhost:5004"
# 添加请求头,需要就传
header = {
"Content-Type": "application/json"
}
formal_question = ""
# 解析前端传输数据
front_data = request.get_json()
print(front_data)
status = front_data['status']
data = front_data['data']
question = data['question']
if status == 200:
# 操作识别
OptReg_input_json = {
"status": status,
"data":
{
"instruction": question
}
}
OptReg_response = requests.post(url=OptReg_request_url, json=OptReg_input_json, headers=header)
# 格式转换
OptReg_output = ast.literal_eval(OptReg_response.content.decode('utf-8'))
if OptReg_output['is_opt'] == 'y':
# 如果是操作问句则直接返回识别结果 (如“打开财务报表”)
res = {
"status": 302,
"data": [
[
{
"key": "operation",
"content": str(OptReg_output['exact_opt'])
}
]
]
}
return jsonify(res)
# 知识图谱规范化
KB_input_json = {
"status": status,
"data":
{
"question": question
}
}
KB_response = requests.post(url=KB_request_url, json=KB_input_json)
# 格式转换
# unicode_escape避免出现中文乱码的问题
KB_output = ast.literal_eval(KB_response.content.decode('unicode_escape'))
KB_data = KB_output['data']
formal_question = KB_data['question']
tag = KB_data['tag']
recommended_queries = KB_data['recommended_queries']
if len(recommended_queries) != 0:
res = {
"status": 301,
"data": recommended_queries
}
return res
# 意图识别
IntentReg_input_json = {
"status": status,
"data": {
"question": formal_question
}
}
IntentReg_response = requests.post(url=IntentReg_request_url, json=IntentReg_input_json)
IntentReg_res = ast.literal_eval(IntentReg_response.content.decode('utf-8'))
if IntentReg_res['status'] == 300:
# 需要用户进行维度选择
# 端到端
End2End_input_json = {
"status": status,
"data": {
"question": formal_question
}
}
End2End_response = requests.post(url=End2End_request_url, json=End2End_input_json)
End2End_res = ast.literal_eval(End2End_response.content.decode('utf-8'))
return FusionMethod1(End2End_res, IntentReg_res)
elif status == 300:
# 用户选择完模糊维度后返回
IntentReg_response = requests.post(url=IntentReg_request_url, json=front_data)
IntentReg_res = ast.literal_eval(IntentReg_response.content.decode('utf-8'))
elif status == 301:
# 用户选择完推荐问句后返回
input_json = {
"status": 200,
"data": {
"question": question
}
}
IntentReg_response = requests.post(url=IntentReg_request_url, json=input_json)
IntentReg_res = ast.literal_eval(IntentReg_response.content.decode('utf-8'))
if IntentReg_res['status'] == 300:
# 需要用户进行维度选择
# 端到端
End2End_input_json = {
"status": status,
"data": {
"question": formal_question if formal_question != "" else question
}
}
End2End_response = requests.post(url=End2End_request_url, json=End2End_input_json)
End2End_res = ast.literal_eval(End2End_response.content.decode('utf-8'))
return FusionMethod1(End2End_res, IntentReg_res)
return jsonify(IntentReg_res)
if __name__ == "__main__":
app.run(host='0.0.0.0', port=5000, debug=True)
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。