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

山东大学项目实训-大数据租房推荐智能体(一)

整体任务搭建完整的agent框架设计项目结构agent工作流程编写prompt和重试机制约束LLM输出实现多轮对话管理让agent能够理解当下环境和用户意图编排正确的工具调用顺序。一第一步是设计和构建项目结构使用codex根据项目任务描述参考Claude Code的agent框架构建项目结构得到如下结构house-recommend/├── data/ # 数据目录│ └── mockListings.json # 模拟房源数据├── docs/ # 文档目录│ ├── architecture.md # 架构文档│ └── prompt_templates_v1.md # 提示模板├── src/ # 源代码目录│ ├── agent/ # 智能体相关代码│ ├── config/ # 配置文件│ ├── domain/ # 领域模型│ ├── memory/ # 记忆系统│ ├── runtime/ # 运行时│ ├── tools/ # 工具定义│ └── types/ # 类型定义├── storage/ # 存储目录├── .env.example # 环境变量示例├── package.json # 依赖配置└── tsconfig.json # TypeScript 配置接着开始编写核心agent代码定义智能体类通过.env配置API和Modelexport class ReactRentalAgent { // 定义智能体模型 private readonly model new ChatOpenAI({ apiKey: env.OPENAI_API_KEY, model: env.OPENAI_MODEL, temperature: 0.2, });使用langchain提供的message类搭建短期记忆后面扩展长期记忆import { AIMessage, BaseMessage, HumanMessage, ToolMessage } from langchain/core/messages; export class ConversationMemory { private readonly messages: BaseMessage[] []; // 定义智能体记忆种子方法 // 用于初始化智能体记忆添加用户输入 // param input 用户输入 seed(input: string) { this.messages.push(new HumanMessage(input)); } // 定义智能体记忆添加方法 // 用于添加智能体回复 // param message 智能体回复 // returns 无 appendAssistant(message: AIMessage) { this.messages.push(message); } // 定义智能体记忆添加方法 // 用于添加工具观察 // param observation 工具观察 // returns 无 appendToolObservation(observation: ToolMessage) { this.messages.push(observation); } // 定义智能体记忆获取方法 // 用于获取智能体记忆中的所有消息 // returns 所有消息的数组 getMessages(): BaseMessage[] { return [...this.messages]; } }编写主循环采用Reasoning Acting的方式agent自行判断是否需要调用工具如果需要使用工具则执行对应工具并将结果加入观察中继续循环直到完成工作。通过AGENT_MAX_ITERATIONS限制agent循环次数避免死循环。先直接使用langchain封装好的工具类简化开发。async run(input: string): PromiseAgentExecutionResult { // 初始化智能体记忆 const memory new ConversationMemory(); memory.seed(input); // 定义智能体执行步骤数组 const steps: AgentExecutionResult[steps] []; // 绑定智能体模型到工具 const toolEnabledModel this.model.bindTools(this.tools); // 执行智能体循环 for (let iteration 0; iteration env.AGENT_MAX_ITERATIONS; iteration 1) { // 调用智能体模型 const response (await toolEnabledModel.invoke(this.buildMessages(memory))) as AIMessage; memory.appendAssistant(response); // 如果智能体回复中没有工具调用返回最终结果 if (!response.tool_calls || response.tool_calls.length 0) { return { output: this.getMessageText(response), steps, }; } // 调用工具 for (const toolCall of response.tool_calls) { // 寻找工具 const tool this.tools.find((candidate) candidate.name toolCall.name); if (!tool) { throw new Error(Tool ${toolCall.name} is not registered.); } // 调用工具并存入steps const observation await tool.invoke(toolCall.args); steps.push({ toolName: toolCall.name, observation: typeof observation string ? observation : JSON.stringify(observation), }); // 存入工具观察 memory.appendToolObservation( new ToolMessage({ tool_call_id: toolCall.id ?? toolCall.name, content: typeof observation string ? observation : JSON.stringify(observation), }), ); } } throw new Error(Agent stopped after ${env.AGENT_MAX_ITERATIONS} iterations without a final answer.); }非核心代码省略避免blog过长目前为止完成了整个项目的基本结构搭建分好了各个模块的文件夹为后续扩展开发打下基础。编写了核心主循环和短期记忆通过langchain框架提供的封装类简化了初期代码构建后续可根据情况决定优化langchain或是自己开发更好的模块。

相关文章:

山东大学项目实训-大数据租房推荐智能体(一)

整体任务搭建完整的agent框架,设计项目结构,agent工作流程,编写prompt和重试机制约束LLM输出,实现多轮对话管理,让agent能够理解当下环境和用户意图,编排正确的工具调用顺序。(一)第…...

为什么你的Spring Boot 4.0 Agent始终“不就绪”?7步诊断清单+ClassLoader隔离冲突终极解法

第一章:Spring Boot 4.0 Agent-Ready 架构演进与核心挑战Spring Boot 4.0 将 JVM Agent 集成能力提升为核心架构特性,标志着从“可监控”迈向“原生可观测”的范式跃迁。该版本深度重构了启动生命周期、类加载器隔离机制与 Bean 注册流程,使字…...

番茄小说下载器高效使用全攻略:轻松获取并管理你喜爱的小说

番茄小说下载器高效使用全攻略:轻松获取并管理你喜爱的小说 【免费下载链接】fanqienovel-downloader 下载番茄小说 项目地址: https://gitcode.com/gh_mirrors/fa/fanqienovel-downloader 在数字阅读时代,拥有一款可靠的小说下载工具能极大提升阅…...

AI写PHP代码=埋雷?资深工程师用237个真实项目数据验证:86%的AI生成函数需强制校验,附开源校验器v1.3

第一章:AI写PHP代码埋雷?237项目实证与校验必要性近期对237个真实PHP开源项目(涵盖Laravel、Symfony及原生框架)的自动化代码审计显示:由主流AI工具生成的PHP代码中,18.6%存在未声明变量导致的运行时错误&a…...

3个高效工作流技巧:用Flut Renamer解决批量文件重命名痛点

3个高效工作流技巧:用Flut Renamer解决批量文件重命名痛点 【免费下载链接】renamer Flut Renamer - A bulk file renamer written in flutter (dart). Available on Linux, Windows, Android, iOS and macOS. 项目地址: https://gitcode.com/gh_mirrors/ren/rena…...

Modbus通信调试难题困扰你?这款开源工具让你轻松成为工业自动化专家

Modbus通信调试难题困扰你?这款开源工具让你轻松成为工业自动化专家 【免费下载链接】ModbusTool A modbus master and slave test tool with import and export functionality, supports TCP, UDP and RTU. 项目地址: https://gitcode.com/gh_mirrors/mo/ModbusT…...

BilibiliDown音频提取指南:从技术侦探视角破解B站无损音质下载难题

BilibiliDown音频提取指南:从技术侦探视角破解B站无损音质下载难题 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader 😳 项目地址: https://gitcode.com/…...

拒绝当“移动台式机”!从华硕天选6到联想拯救者,这五款游戏本让你在图书馆也能畅玩3A

一、目的为学生党和需要移动办公的玩家推荐五款在高性能与长续航之间取得良好平衡的高性价比游戏本,帮助用户摆脱对电源插座的依赖,在教室、图书馆或差旅途中也能从容使用。二、推荐机型详细对比型号核心配置存储与屏幕主要优势与特点参考价格华硕天选6 …...

互联网大厂Java求职者面试实录:严肃面试官VS搞笑水货程序员小李

互联网大厂Java求职者面试实录:严肃面试官VS搞笑水货程序员小李 第一轮提问:Java基础与多线程 面试官:小李,Java中HashMap的工作原理是什么?当多线程并发访问时会出现什么问题? 小李:HashMap就是…...

Cursor Pro免费使用终极指南:绕过试用限制的完整解决方案

Cursor Pro免费使用终极指南:绕过试用限制的完整解决方案 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your …...

3分钟获取阿里云盘Refresh Token:告别手动认证的自动化解决方案

3分钟获取阿里云盘Refresh Token:告别手动认证的自动化解决方案 【免费下载链接】aliyundriver-refresh-token QR Code扫码获取阿里云盘refresh token For Web 项目地址: https://gitcode.com/gh_mirrors/al/aliyundriver-refresh-token 解决云存储认证难题&…...

Python数据分析环境部署:Anaconda与Phi-3-mini协作指南

Python数据分析环境部署:Anaconda与Phi-3-mini协作指南 1. 为什么选择这个组合? 在开始动手之前,我们先聊聊为什么Anaconda和Phi-3-mini是数据科学家的好搭档。Anaconda就像是一个瑞士军刀,把Python环境管理和包依赖这些麻烦事都…...

PPTist:基于Vue3与TypeScript的在线演示文稿技术架构解析

PPTist:基于Vue3与TypeScript的在线演示文稿技术架构解析 【免费下载链接】PPTist PowerPoint-ist(/pauəpɔintist/), An online presentation application that replicates most of the commonly used features of MS PowerPoint, allowing…...

终极指南:通过cursor-free-vip开源工具实现Cursor Pro无限制访问

终极指南:通过cursor-free-vip开源工具实现Cursor Pro无限制访问 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reache…...

DTime嵌入式日期时间库:零依赖、确定性、全周期格里高利历计算

1. DTime库概述:嵌入式系统中的日期时间服务设计与实现在嵌入式开发实践中,RTC(实时时钟)硬件模块虽能提供秒级精度的时间计数,但其寄存器通常仅存储BCD或二进制格式的年、月、日、时、分、秒字段,不直接支…...

svgpath:突破SVG路径操控瓶颈的底层技术解密

svgpath:突破SVG路径操控瓶颈的底层技术解密 【免费下载链接】svgpath SVG path low level transformations toolkit 项目地址: https://gitcode.com/gh_mirrors/sv/svgpath 开篇:当动画遇到坐标迷宫 在开发交互式SVG图表时,你是否曾…...

AsrTools:免费语音转文字工具的全方位应用指南

AsrTools:免费语音转文字工具的全方位应用指南 【免费下载链接】AsrTools ✨ AsrTools: Smart Voice-to-Text Tool | Efficient Batch Processing | User-Friendly Interface | No GPU Required | Supports SRT/TXT Output | Turn your audio into accurate text in…...

Python敏感词检测方案详解

一、引言在互联网内容审核、社交平台监管、评论系统过滤等场景中,敏感词检测是一项必不可少的功能。Python凭借其丰富的生态和简洁的语法,提供了多种实现敏感词检测的方案。本文将详细介绍几种主流的实现方式,并分析各自的优缺点及适用场景。…...

STM32F103移相全桥PWM寄存器级配置实战

1. STM32F103移相全桥PWM控制的核心原理 移相全桥拓扑在DCDC电源设计中非常常见,它通过调节两个桥臂之间的相位差来控制功率传输。STM32F103的高级定时器TIM1和TIM8正好可以完美实现这个功能。我做过好几个电源项目,发现直接操作寄存器比用库函数效率高得…...

fastMRI技术解析:从k-space到图像重建的完整指南

fastMRI技术解析:从k-space到图像重建的完整指南 【免费下载链接】fastMRI A large-scale dataset of both raw MRI measurements and clinical MRI images. 项目地址: https://gitcode.com/gh_mirrors/fa/fastMRI 1 问题引入:医疗影像的"速…...

直连链接获取:告别城通网盘下载烦恼的高效解决方案

直连链接获取:告别城通网盘下载烦恼的高效解决方案 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 在数字化办公与学习中,城通网盘作为常用的文件存储与分享平台,其下…...

胡桃讲编程:华为鸿蒙系统能装安卓安装包吗?

(地下程序员实战科普|无废话纯原理版)哈喽各位抱着老本搞开发、做音频创作、天天和各种安装包打交道的小伙伴们,我是胡桃~前面咱们刚讲完 USB 2.0 和 3.0 的速度与分级逻辑,这期来聊一个数码圈常年有人问的…...

Snap.Hutao:5分钟掌握原神玩家必备的终极桌面工具箱

Snap.Hutao:5分钟掌握原神玩家必备的终极桌面工具箱 【免费下载链接】Snap.Hutao 实用的开源多功能原神工具箱 🧰 / Multifunctional Open-Source Genshin Impact Toolkit 🧰 项目地址: https://gitcode.com/GitHub_Trending/sn/Snap.Hutao…...

VRCT:突破VRChat语言壁垒的创新解决方案

VRCT:突破VRChat语言壁垒的创新解决方案 【免费下载链接】VRCT VRCT(VRChat Chatbox Translator & Transcription) 项目地址: https://gitcode.com/gh_mirrors/vr/VRCT 在全球化的虚拟社交平台VRChat中,语言差异已成为阻碍跨文化交流的核心痛…...

胡桃讲编程|从代码跨入音乐:调音,本质就是另一种编程!(MIDI 核心概念篇)

哈喽各位抱着老本搞开发、跑 AI 音频、玩虚拟歌手的小伙伴们,我是胡桃~之前咱们一直在聊电脑蓝屏、CMD 指令、硬件续命、鸿蒙实操,从今天开始,咱们正式踏入一个全新的领域 ——音乐创作。 不知道你们有没有过这样一种奇妙的感觉&…...

OpenClaw版本升级指南:Qwen3-14b_int4_awq兼容性检查清单

OpenClaw版本升级指南:Qwen3-14b_int4_awq兼容性检查清单 1. 为什么需要这份升级指南 上周五晚上11点,我的OpenClaw突然罢工了——当时它正在帮我自动整理会议纪要,突然弹出一条错误提示:"Model provider configuration in…...

提升JSON处理效率的三个核心技巧:使用VS Code插件优化开发流程

提升JSON处理效率的三个核心技巧:使用VS Code插件优化开发流程 【免费下载链接】vscode-json Json for Visual Studio Code 项目地址: https://gitcode.com/gh_mirrors/vs/vscode-json 在现代软件开发中,JSON作为数据交换的标准格式,其…...

收银系统搭建难点解决方法

收银系统是现代零售、餐饮等行业的核心工具,能提升效率、减少错误。但搭建过程中常面临技术难点,如支付集成、安全合规等。本文基于实际实践,提供解决方法,帮助读者从零构建高效系统。需求分析难点及解决需求模糊或冲突是常见难点…...

Phi-4-mini-reasoning与SpringBoot微服务集成:构建智能业务逻辑层

Phi-4-mini-reasoning与SpringBoot微服务集成:构建智能业务逻辑层 1. 为什么要在微服务中集成AI推理能力 微服务架构已经成为现代企业应用开发的主流选择,而AI能力的引入正在改变传统业务逻辑的实现方式。将Phi-4-mini-reasoning这样的轻量级推理模型集…...

OPUS编解码器在audio DSP上的移植和应用贩

前言 在使用 kubectl get $KIND -o yaml 查看 k8s 资源时,输出结果中包含大量由集群自动生成的元数据(如 managedFields、resourceVersion、uid 等)。这些信息在实际复用 yaml 清单时需要手动清理,增加了额外的工作量。 使用 kube…...