当前位置: 首页 > java >正文

用户意图识别模块

##用户意图识别模块

该模块主要用于收集用户想要去哪,去几天的需求。我们可以通过一个合适的system prompt来实现,为了后续在软件开发中的前后端分离的设计,我们还需要进一步通过flask将该模块封装成一个本地服务——

import os
import sys
import json
from typing import Optional
from flask import Flask, request, jsonify,Responsefrom dotenv import load_dotenv
from camel.configs import QwenConfig
from camel.models import ModelFactory
from camel.types import ModelPlatformType
from camel.agents import ChatAgentload_dotenv()API_KEY = os.getenv('QWEN_API_KEY')SYSTEM_PROMPT = """
你是一个旅游信息提取助手。你的任务是从用户的输入中提取旅游目的地城市和行程天数,并根据提取情况决定是否需要用户补充信息。用户输入可能包含以下信息:
* 旅游目的地城市名称(例如:北京、上海、巴黎、东京)
* 行程天数(例如:3天、5天、一周、两周)
* 可能会有其他无关信息,请忽略。你需要将提取到的城市名称和行程天数以 JSON 格式返回,格式如下:
{"city": "城市名称", "days": 天数, "need_more_info": boolean}
* "city" 的值:* 如果成功提取到城市名称,则为城市名称字符串。* 如果无法提取到城市名称,则为 null。
* "days" 的值:* 如果成功提取到行程天数,则为数字。* 如果无法提取到行程天数,则为 null。
* "need_more_info" 的值:* 如果 "city" 或 "days" 中有任何一个为 null,则为 true,表示需要用户提供更多信息。* 如果 "city" 和 "days" 都不为 null,则为 false,表示不需要用户提供更多信息。
* 如果提取到的天数包含“天”或“日”等字样,请将其转换为数字。
* 如果提取到的天数包含“周”或“星期”,请将其转换为7的倍数。例如,“一周”转换为7,“两周”转换为14。
* 如果用户输入中包含多个城市,请只提取第一个城市。
* 如果用户输入中包含多个天数,请只提取第一个天数。请严格按照 JSON 格式返回结果。**示例:****用户输入:**
我想去北京玩三天,顺便看看长城。**你的输出:**
{"city": "北京", "days": 3, "need_more_info": false,"response": "信息在Navigator的数据库中查询到啦,正在努力为您生成攻略~"}**用户输入:**
我想去北京。**你的输出:**
{"city": "北京", "days": null, "need_more_info": true,"response": "Navigator还不知道您打算去玩几天呢,请补充你计划的行程天数~"}
"""app = Flask(__name__)def create_travel_agent():qwen_model = ModelFactory.create(model_platform=ModelPlatformType.OPENAI_COMPATIBLE_MODEL,model_type="Qwen/Qwen2.5-72B-Instruct",api_key=API_KEY,url="https://api-inference.modelscope.cn/v1",model_config_dict=QwenConfig(temperature=0.2).as_dict(),)agent = ChatAgent(system_message=SYSTEM_PROMPT,model=qwen_model,message_window_size=10,output_language='Chinese')return agenttravel_agent = create_travel_agent()def get_travel_info_camel(user_input: str, agent: ChatAgent) -> dict:try:response = agent.step(user_input)# 回到原始状态agent.reset()if not response or not response.msgs:raise ValueError("模型没有返回任何消息")json_output = response.msgs[0].content.strip().replace("```json", "").replace("```", "").strip()json_output = json.loads(json_output)json_output["query"] = user_inputreturn json_outputexcept json.JSONDecodeError:print("Error: 模型返回的不是有效的 JSON 格式。")return {'city': None,'days': None,'need_more_info': True,'query': user_input,'response': None}except Exception as e:print(f"An unexpected error occurred: {e}")return {'city': None,'days': None,'need_more_info': True,'query': user_input,'response': None}@app.route('/extract_travel_info', methods=['POST'])
def extract_travel_info():try:request_data = request.get_json()if not request_data or 'query' not in request_data:return jsonify({'error': '请求数据无效'}), 400result = get_travel_info_camel(request_data['query'], travel_agent)response = {'city': result['city'],'days': result['days'],'need_more_info': result['need_more_info'],'query': result['query'],'response': result['response']}response_json = json.dumps(response, ensure_ascii=False)return Response(response_json, status=200, mimetype='application/json; charset=utf-8')except Exception as e:return jsonify({'error': f'服务器内部错误: {str(e)}'}), 500if __name__ == "__main__":app.run(host="0.0.0.0", port=5001)

这个模块运行之后会在本地5001端口启动一个服务,我们可以通过请求这个服务来和模块中的信息收集Agent进行多轮交互

使用Python requests库的示例代码

import requestsurl = "http://localhost:8000/extract_travel_info"
data = {"query": "我想去北京玩三天"}
response = requests.post(url, json=data)
print(response.json())>>>
{'city': '北京', 'days': 3, 'need_more_info': False, 'query': '我想去北京玩三天', 'response': '信息已经获取,正在帮你生成攻略。'}

使用curl的示例命令行,这次我们不说清楚需求试试:

curl -X POST http://localhost:8000/extract_travel_info \
-H "Content-Type: application/json" \
-d '{"query": "我想去北京玩"}'>>>
{"city": "北京", "days": null, "need_more_info": true, "query": "我想去北京玩", "response": "请补充旅游天数,你打算去玩几天呀。"}

通过上述两个测试的示例可以观察到信息收集模块的核心功能会让我们在信息表述不全的情况下自主的分析问题并引导提示我们补充行程天数,有的小伙伴可能会觉得,根本没必要这样做呀,直接在开始界面设置弹窗让用户输入城市和天数不就行了,其实这个方案我们也考虑过,这样确实更方便快捷,而我们在方案中特意添加了这个模块是为了考虑到后续可能有更多的交互空间的拓展,比如情感陪伴等。当然,适合自己的方案就是最好的!Enjoy!

http://www.xdnf.cn/news/8299.html

相关文章:

  • 跟Gemini学做PPT:字号选择
  • MyBatisPlus使用教程
  • Ubuntu 上进行树莓派交叉编译
  • hadoop 无法存储数据到hbase里面 已经解决
  • 鸿蒙仓颉开发语言实战教程:实现商城应用详情页
  • SpringBoot Day_03|数据校验|异常处理|日志级别|定时器
  • Java使用CollectionUtils集合工具类
  • 大模型相关数据格式及训练器接收的数据格式
  • 云南安全员考试报名需要具备哪些条件?
  • 【深度学习-Day 15】告别“盲猜”:一文读懂深度学习损失函数
  • VSCode C/C++ 开发环境完整配置及一些扩展用途(自用)update:2025/3/31
  • 英语学习5.21
  • 【项目记录】部门增删改及日志技术
  • 超声仿真乳腺体模的主要声学参数
  • 3 PID控制学习指南
  • el-form elform 对齐方式调整
  • mysql安全管理
  • 【C/C++】虚拟内存空间问题整理_可用于验证掌握情况
  • WebTransport 低延迟通信
  • 解决SQL Server SQL语句性能问题(9)——创建和更新统计对象
  • Spring的事务传播行为
  • PCB设计教程【入门篇】——电路分析基础-电路定理
  • tf 重排 切分 逆排列
  • mysql日志文件binlog分析记录
  • 结构性断裂:中年失业潮与婚姻解体的崩溃逻辑
  • 数学基础知识:三角函数
  • 【打卡】车厢重排
  • java后端-海外登录(谷歌/FaceBook/苹果)
  • 汽配知识(四)不同车型与区域市场的分类差异
  • 率先实现混合搜索:使用 Elasticsearch 和 Semantic Kernel