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

AI回答太冗长?我设计了三段式流式显示让信息层次分明

我是张大鹏做了十多年人工智能带过不少项目。说实话最难的不是让AI生成正确的答案是让答案以正确的方式呈现给用户。最近Claude 3.7推出了extended thinking模式OpenAI的o系列也在做类似的事情——让AI的推理过程可见。但我们在如意Agent里做这件事的时候发现单纯的显示思考过程不够用户真正需要的是信息分层。一、传统AI输出的痛点用过ChatGPT或Claude的都知道AI回答问题的典型流程是你提了一个复杂问题屏幕开始滚动AI滔滔不绝你盯着屏幕看了30秒还没看到重点最后发现答案藏在第8段前面全是推理过程这种一镜到底的输出方式在简单问答时没问题。但在多轮工具调用、复杂推理的场景下体验很糟糕场景问题用户感受工具调用AI先思考用哪个工具再调用再分析结果再决定下一步“到底在干嘛进度多少了”长推理1000字的思考过程最后结论只有50字“前面这么多字就为了说这么点事”多轮对话历史上下文混在一起新信息被淹没“好像之前说过这个是不是重复了”我们的核心需求很明确让思考过程可见但不干扰让结论突出但不突兀让详细回答有序但不冗长。二、三段式流式显示设计基于上面的分析我们设计了thinking / summary / answer三段式流式显示。2.1 三段定义段落内容显示策略目的thinkingAI的推理过程、工具调用分析、策略调整可折叠默认收起满足好奇心不干扰阅读summary极简单行概括30字包含关键结论独立高亮显示快速获取核心信息answer详细回答、代码示例、数据表格主体展示获取完整信息2.2 消息协议设计后端流式输出的消息格式classMessageBlock(BaseModel):type:Literal[thinking,summary,answer]content:stris_complete:boolFalseWebSocket推送时每个block独立发送{type:thinking,content:正在分析项目结构...,is_complete:false}{type:thinking,content:发现3个相关模块优先检查handler层,is_complete:true}{type:summary,content:问题根源在HTTP流重试逻辑建议检查第47行,is_complete:true}{type:answer,content:详细分析如下...,is_complete:false}关键点type字段让前端知道当前收到的是什么内容is_complete字段标记段落是否结束用于UI状态更新独立推送保证即使thinking很长summary和answer也能及时到达2.3 前端渲染策略终端版Rich的实现fromrich.liveimportLivefromrich.panelimportPanelfromrich.markdownimportMarkdownfromrich.layoutimportLayoutclassStreamingDisplay:def__init__(self,console):self.consoleconsole self.thinkingself.summaryself.answerself.show_thinkingFalse# 默认折叠defupdate(self,block:MessageBlock):ifblock.typethinking:self.thinkingblock.contentelifblock.typesummary:self.summaryblock.contentelifblock.typeanswer:self.answerblock.content self._render()def_render(self):layoutLayout()# summary 始终显示在最上方ifself.summary:layout.split_column(Layout(Panel(f{self.summary},stylebold cyan)),Layout(self._build_main_content()))else:layoutself._build_main_content()self.live.update(layout)def_build_main_content(self):# thinking 可折叠ifself.show_thinkingandself.thinking:thinking_panelPanel(self.thinking,title 思考过程,styledim)else:thinking_panel# answer 主体answer_panelPanel(Markdown(self.answer),title如意Agent)returnLayout(thinking_panelanswer_panel)Web版Vue3的实现更简单用v-if控制折叠template div classmessage-blocks !-- summary 始终显示 -- div v-ifsummary classsummary-block {{ summary }} /div !-- thinking 可折叠 -- div v-ifthinking classthinking-section button clicktoggleThinking {{ showThinking ? 收起 : 查看思考过程 }} /button div v-showshowThinking classthinking-block {{ thinking }} /div /div !-- answer 主体 -- div classanswer-block v-htmlrenderedAnswer/div /div /template三、后端解析实现三段式的核心难点在解析LLM返回的是纯文本流如何从中提取出thinking、summary、answer3.1 标签约定我们在system prompt中要求LLM按固定格式输出thinking 分析当前情况... 决定使用哪个工具... /thinking summary 极简单行概括30字 /summary 详细回答... 代码示例...这个约定有几个好处结构化标签明确解析简单向后兼容不支持标签的LLM内容会全部落入answer可扩展未来增加新段落类型只需加新标签3.2 流式解析器解析器需要处理流式输入不能等全部内容到达再解析importrefromtypingimportGeneratorclassStreamParser:def__init__(self):self.bufferself.current_blockNonedefparse(self,text_stream:Generator[str,None,None])-Generator[MessageBlock,None,None]:流式解析文本实时产出MessageBlockforchunkintext_stream:self.bufferchunk# 检查是否完整捕获了一个标签块forblock_type,patternin[(thinking,rthinking([

相关文章:

AI回答太冗长?我设计了三段式流式显示让信息层次分明

我是张大鹏,做了十多年人工智能,带过不少项目。说实话,最难的不是让AI生成正确的答案,是让答案以正确的方式呈现给用户。最近Claude 3.7推出了extended thinking模式,OpenAI的o系列也在做类似的事情——让AI的推理过程…...

DesignPatternsPHP:工厂方法模式实战应用场景终极指南

DesignPatternsPHP:工厂方法模式实战应用场景终极指南 【免费下载链接】DesignPatternsPHP Sample code for several design patterns in PHP 8.x 项目地址: https://gitcode.com/gh_mirrors/de/DesignPatternsPHP 工厂方法模式是PHP开发中最实用的设计模式之…...

5分钟掌握批量照片水印添加:摄影师的智能EXIF信息处理利器

5分钟掌握批量照片水印添加:摄影师的智能EXIF信息处理利器 【免费下载链接】semi-utils 一个批量添加相机机型和拍摄参数的工具,后续「可能」添加其他功能。 项目地址: https://gitcode.com/gh_mirrors/se/semi-utils 摄影爱好者和专业摄影师经常…...

大模型幻觉深度解析:成因、落地危害与工程级解决方案

一、前言当下生成式AI大模型已经全面落地到企业知识库、智能问答、代码生成、文案创作、数据分析等各类开发场景。但绝大多数开发者在项目落地中都会遇到一个共性难题:大模型看似输出流畅、逻辑通顺,但频繁出现事实错误、编造数据、杜撰案例和专业结论。…...

AI开发新范式:在快马平台用Kimi模型辅助设计多智能体协作系统架构

最近在尝试用AI辅助开发一个多智能体协作系统,发现整个过程比想象中顺利很多。特别是在InsCode(快马)平台上,借助集成的Kimi模型,可以很高效地完成从架构设计到代码实现的全流程。这里分享一下我的实践过程,希望对想尝试AI辅助开发…...

基于MCP协议构建安全可控的AI浏览器自动化工具

1. 项目概述:一个让AI安全“上网”的桥梁最近在折腾AI应用开发,特别是想让大语言模型(LLM)能像人一样操作浏览器,去获取实时信息、执行网页任务。这听起来很酷,但实际操作起来,安全性和可控性是…...

ExcelJS终极指南:JavaScript电子表格处理的完整解决方案

ExcelJS终极指南:JavaScript电子表格处理的完整解决方案 【免费下载链接】exceljs Excel Workbook Manager 项目地址: https://gitcode.com/gh_mirrors/ex/exceljs ExcelJS是一款功能强大的JavaScript电子表格处理库,它允许开发者在浏览器和Node.…...

3分钟上手:用easy-topo绘制专业网络拓扑图

3分钟上手:用easy-topo绘制专业网络拓扑图 【免费下载链接】easy-topo vuesvgelement-ui 快捷画出网络拓扑图 项目地址: https://gitcode.com/gh_mirrors/ea/easy-topo 还在为绘制复杂的网络架构图而烦恼吗?easy-topo来帮你!这是一个基…...

3个步骤将Obsidian升级为智能知识助手:obsidian-copilot终极指南

3个步骤将Obsidian升级为智能知识助手:obsidian-copilot终极指南 【免费下载链接】obsidian-copilot THE Copilot in Obsidian 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-copilot 在信息过载的时代,我们每天处理海量笔记却难以高效提…...

Docker Cheat Sheet:数据一致性保障策略终极指南

Docker Cheat Sheet:数据一致性保障策略终极指南 【免费下载链接】docker-cheat-sheet Docker Cheat Sheet 项目地址: https://gitcode.com/gh_mirrors/do/docker-cheat-sheet Docker Cheat Sheet是一份全面的Docker使用指南,涵盖从基础安装到高级…...

OpenCV C++ KNN模型训练避坑指南:从制作自己的手写数字数据集到保存model.xml

OpenCV C KNN模型训练实战:从手写数字识别到工业级部署的完整指南 在计算机视觉领域,手写字符识别一直是验证机器学习算法有效性的经典案例。不同于直接调用现成的MNIST数据集,从零开始构建自己的手写数字识别系统能够让我们深入理解机器学习…...

英派药业开启招股:拟募资9亿港元 5月13日上市 腾讯与药明康德加持

雷递网 雷建平 5月5日南京英派药业股份有限公司(简称:“英派药业”,股票代码:“07630”)日前开启招股,准备2026年5月13日在港交所上市。英派药业发行区间为每股19.75港元至21.75港元,发行4197.7…...

图神经网络:复杂关系数据分析的终极指南

图神经网络:复杂关系数据分析的终极指南 【免费下载链接】fastbook The fastai book, published as Jupyter Notebooks 项目地址: https://gitcode.com/gh_mirrors/fa/fastbook 图神经网络(GNN)是一种专门处理图结构数据的深度学习模型…...

【MCP 2026边缘部署性能优化黄金五步法】:20年一线架构师亲授,避开92%团队踩过的实时推理延迟陷阱

更多请点击: https://intelliparadigm.com 第一章:MCP 2026边缘部署性能优化的底层逻辑与范式跃迁 MCP 2026(Model Control Plane 2026)并非简单延续传统云原生调度范式,而是以“确定性时延契约”为第一性原理重构边缘…...

终极指南:一键合并B站缓存视频,完整保留弹幕体验

终极指南:一键合并B站缓存视频,完整保留弹幕体验 【免费下载链接】BilibiliCacheVideoMerge 🔥🔥Android上将bilibili缓存视频合并导出为mp4,支持安卓5.0 ~ 13,视频挂载弹幕播放(Android consolidates and …...

【油浸式变压器】在不同气候条件下的油浸式变压器的能量极限研究附Matlab代码

​✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、程序设计科研仿真。 🍎完整代码获取 定制创新 论文复现点击:Matlab科研工作室 👇 关注我领取海量matlab电子书和数学建模资料 &am…...

别再手动贴标签了!用BarTender 2021直连MySQL数据库,批量打印带二维码的标签(保姆级图文教程)

从数据到标签:BarTender 2021与MySQL深度整合实战指南 在仓库管理、电商运营和生产线等场景中,标签打印是日常工作中不可或缺的一环。传统的手动输入方式不仅效率低下,还容易出错——一个数字的错位可能导致整个批次标签作废。想象一下&#…...

HuggingChat macOS:终极AI聊天助手,一键开启桌面智能对话革命

HuggingChat macOS:终极AI聊天助手,一键开启桌面智能对话革命 【免费下载链接】chat-macOS Making the communitys best AI chat models available to everyone. 项目地址: https://gitcode.com/gh_mirrors/ch/chat-macOS HuggingChat macOS是一款…...

别再只调参了!用EfficientNetV2-S在PyTorch上实现渐进式学习,让你的图像分类模型训练快3倍

高效图像分类实战:用EfficientNetV2-S实现三倍速训练的渐进式学习策略 当你在深夜盯着缓慢下降的损失曲线,看着GPU利用率波动却无法提升batch size时,是否想过——那些被我们忽视的训练策略可能比模型架构更能决定最终效率?Effici…...

网盘直链下载终极指南:告别限速,拥抱全平台高速下载新时代

网盘直链下载终极指南:告别限速,拥抱全平台高速下载新时代 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国…...

Topit终极指南:让Mac窗口置顶显示的高效生产力工具

Topit终极指南:让Mac窗口置顶显示的高效生产力工具 【免费下载链接】Topit Pin any window to the top of your screen / 在Mac上将你的任何窗口强制置顶 项目地址: https://gitcode.com/gh_mirrors/to/Topit 你是否曾经在多个应用间频繁切换,只为…...

从“代码搬运“到“安全守护“,程序员转网安的黄金赛道,建议收藏!

引言:从 “代码搬运” 到 “安全守护”,程序员转行的新趋势 打开招聘平台不难发现一个现象:越来越多标注 “5 年 Java 开发”“3 年前端工程师” 的简历,在技能栏里新增了 “渗透测试”“代码审计”“漏洞挖掘” 等关键词&#x…...

5分钟终极指南:用MelonLoader为Unity游戏添加模组的完整教程

5分钟终极指南:用MelonLoader为Unity游戏添加模组的完整教程 【免费下载链接】MelonLoader The Worlds First Universal Mod Loader for Unity Games compatible with both Il2Cpp and Mono 项目地址: https://gitcode.com/gh_mirrors/me/MelonLoader 你是否…...

测试数据管理:打造高质量、合规、可复用的数据工厂

测试数据的“石油危机”在软件测试的日常中,我们时常陷入这样的困境:自动化脚本因一条过期订单数据而大面积飘红;性能测试因数据量不足而无法模拟真实峰值;安全测试因缺乏脱敏数据而被迫在“裸奔”的环境里小心翼翼。这些问题的根…...

视觉AI测试:如何让机器“看懂”UI并自动验证?

一、为什么UI测试需要一双“视觉的眼睛”传统UI自动化测试长期依赖DOM结构、控件ID或XPath来定位元素,这在功能验证上足够高效,却始终存在一个盲区:机器能“点到”按钮,却看不见按钮是否错位、颜色是否偏差、文字是否重叠。这些问…...

为什么83%的MCP 2026早期部署团队在第47小时触发级联超时?——基于127个集群日志的智能调度阈值预警模型首次公开

更多请点击: https://intelliparadigm.com 第一章:为什么83%的MCP 2026早期部署团队在第47小时触发级联超时?——基于127个集群日志的智能调度阈值预警模型首次公开 这一现象并非偶然故障,而是MCP 2026调度器在默认配置下与真实工…...

TB6600驱动器共阴共阳接法傻傻分不清?一张图搞定STM32与42步进电机的接线避坑指南

TB6600驱动器共阴共阳接法全解析:STM32与42步进电机高效连接实战 第一次拿到TB6600驱动器和42步进电机时,面对DIR、DIR-、PUL、PUL-这些接口,我完全懵了。更让人头疼的是,网上关于共阴和共阳接法的说法五花八门,有的教…...

架构革命:完美信息蒸馏技术如何重塑不完美信息博弈AI新范式

架构革命:完美信息蒸馏技术如何重塑不完美信息博弈AI新范式 【免费下载链接】PerfectDou [NeurIPS 2022] PerfectDou: Dominating DouDizhu with Perfect Information Distillation 项目地址: https://gitcode.com/gh_mirrors/pe/PerfectDou 在复杂的不完美…...

让家庭网络永不掉线:luci-app-aliddns动态域名解析终极指南

让家庭网络永不掉线:luci-app-aliddns动态域名解析终极指南 【免费下载链接】luci-app-aliddns OpenWrt/LEDE LuCI for AliDDNS 项目地址: https://gitcode.com/gh_mirrors/lu/luci-app-aliddns 你是否曾遇到过这样的尴尬时刻:出差在外急需访问家…...

QQ聊天记录解密终极指南:全平台数据库密钥提取完整方案

QQ聊天记录解密终极指南:全平台数据库密钥提取完整方案 【免费下载链接】qq-win-db-key 全平台 QQ 聊天数据库解密 项目地址: https://gitcode.com/gh_mirrors/qq/qq-win-db-key 你是否曾因更换设备而无法查看珍贵的QQ聊天记录?或者想要备份多年的…...