支持私有化部署
AI知识库

53AI知识库

学习大模型的前沿技术与行业应用场景


基于Dify平台实现推荐问题点击交互功能的技术方案

发布日期:2025-06-30 11:04:06 浏览次数: 1550
作者:小南瓜开发平台

微信搜一搜,关注“小南瓜开发平台”

推荐语

Dify平台如何实现智能对话的点击交互?一文掌握推荐问题功能的技术实现。

核心内容:
1. 自定义输出格式解决传统对话局限
2. 模板转换节点实现HTML/JSON数据格式化
3. 三步搭建智能对话推荐系统架构

杨芳贤
53AI创始人/腾讯云(TVP)最具价值专家

自定义输出格式:打造智能对话新体验

    在当今数字化交流日益频繁的时代,智能对话系统已成为众多平台与用户互动的关键桥梁。而自定义输出格式技术的出现,为智能对话开辟了全新的个性化路径,使得对话交互不再局限于单一文本回复,而是能够根据具体场景和用户需求,灵活呈现出多样化的交互形式,极大增强了用户体验与对话实用性。
本文将深入浅出地解析自定义输出格式在智能对话系统中的应用,助力读者轻松掌握这一前沿技术,实现智能对话体验的升级。

一、业务场景:突破传统对话局限

在实际应用中,智能对话系统常常面临一个关键挑战:当需要向用户展示非文本内容,如推荐问题列表,并且期望用户点击后能自动触发下一轮对话时,dify 官方自带的推荐功能往往难以满足个性化需求。
例如,在一个知识问答社区中,当用户提出一个问题后,系统不仅要给出针对性的解答,还希望能够基于用户的历史提问记录,为其推荐一系列相关问题,引导用户进行更深入的探索。此时,传统的文本回复方式显然无法实现这种交互效果,因为用户需要通过点击操作来选择感兴趣的问题,进而自动进入下一轮对话。这种场景下,自定义输出格式技术应运而生,为解决此类问题提供了有效的解决方案。

二、解决方案:模板转换节点的妙用

模板转换节点凭借其对 Jinja2 模板语言的强大支持,在数据处理和格式化方面展现出独特优势,完美契合了上述业务场景的需求。

通过合理运用模板转换节点,可以轻松实现复杂场景下的自定义输出,如生成整洁的 HTML 表格、格式化 JSON 数据,或者拼接出精准的提示词等。在我们提到的知识问答场景中,它能够将推荐问题列表以按钮形式呈现给用户,每个按钮携带对应问题信息,用户点击后即可自动触发后续对话流程,从而实现流畅、高效的交互体验。

三、操作步骤详解:搭建智能对话自定义输出架构

1、会话变量节点设置 :会话变量节点在整个流程中扮演着关键的 “记忆” 角色。我们需要在该节点新增一个变量,用于专门存储用户的历史记录。这就好比为系统配备了一个专属的 “笔记本”,每当用户与系统进行交互时,系统都会将相关记录及时更新到这个 “笔记本” 中,以便后续能够根据用户的历史行为做出精准的推荐和响应。



2、变量赋值节点配置 :在大模型节点之后,紧接着新增一个变量赋值节点。这个节点的主要任务是将用户的提问信息妥善保存到之前创建的会话变量中。为了确保信息传递的准确性和一致性,必须将模型的回复格式设置为 json 或者 json object。因为这种格式具有良好的结构化特性,便于后续在代码执行节点和其他节点中对数据进行解析和处理,就如同为信息搭建了一座标准化的 “桥梁”,确保数据能够顺畅无阻地在各个节点之间流转。

3、LLM 节点分析与推荐 :新增 LLM 节点,其核心使命是分析用户提出的问题,并基于分析结果给出一系列推荐问题。这一步骤犹如系统大脑的深度思考过程,通过对用户问题背后意图的挖掘和理解,结合系统内部的知识库以及用户的历史记录,筛选出最有可能符合用户兴趣和需求的相关问题,为后续的个性化推荐提供有力支撑。

注:需要置模型的回格式json或者json object



4、代码执行节点处理 :在这个节点中,需要运用 Python 代码对推荐问题进行格式转换,使其以字典形式呈现。代码逻辑如下:首先,尝试将输入字符串解析为字典;然后,从解析后的数据中提取 answer 列表(需注意键可能存在空格,如 “answer ”);最后,将提取的 answers 以 “result” 为键封装成一个新的字典并返回。这一过程相当于对推荐问题数据进行精细化加工,使其符合后续模板转换节点的输入要求,为生成自定义输出格式奠定基础。若输入数据不是合法的 JSON 字符串,则直接返回原字符串,以保证流程的鲁棒性。

import jsondef main(arg1: str) -> dict:try:# 解析输入字符串为字典data = json.loads(arg1)# 提取answer列表(注意键可能包含空格'answer ')answers = data.get("answer", [])return {"result": answers}except json.JSONDecodeError:# 如果不是合法的JSON字符串,返回原字符串return {"result": arg1}


5.模板转换节点渲染 :新增模板转换节点,利用 Jinja2 模板语法渲染推荐问题模板。具体模板代码为:{% for item in arg1 %}button data-message="{{item}}" data-variant="tertiary">{{ item }} /button{% endfor%}。这段模板代码的作用是遍历推荐问题列表,为每个问题生成一个按钮元素。其中,data-message 属性用于控制点击按钮后发送到下一轮对话的消息内容,确保系统能够准确识别用户的选择并做出相应响应;data-variant 属性则用于控制按钮的样式,使其在视觉上更加美观、直观,提升用户体验。

{% for item in arg1 %}<button data-message="{{item}}" data-variant="tertiary">{{ item }}</button>{% endfor %}


6、直接回复节点输出 :最后,新增直接回复节点,将模板转换后的结果以直观的形式呈现给用户。通过这一节点,自定义输出的按钮元素正式进入用户视野,用户可以便捷地点击按钮,选择感兴趣的问题,进而触发下一轮对话,实现整个智能对话流程的无缝衔接。


7、执行效果

四、button 使用示例:打造个性化交互界面

为了帮助开发者更好地理解和运用自定义输出格式中的 button 元素,附件中提供了丰富的示例代码以及相关参考文档链接。例如,通过设置不同的 data-variant 属性值,可以轻松创建出具有不同样式风格的按钮,如 primary、warning、secondary 等。这使得开发者能够根据实际应用场景和品牌设计规范,打造出独具特色的交互界面,满足不同用户的审美需求。同时,每个按钮的 data-message 属性确保了点击后能够正确传递相应的消息内容,维持对话的连贯性与逻辑性。

<button data-message="Hello World" data-variant="primary">YOYOYO</button><button data-message="Hello World" data-variant="warning">YOYOYO</button><button data-message="Hello World" data-variant="secondary">YOYOYO</button><button data-message="Hello World" data-variant="secondary-accent">YOYOYO</button><button data-message="Hello World" data-variant="ghost">YOYOYO</button><button data-message="Hello World" data-variant="ghost-accent">YOYOYO</button>
data-variant:可以控制按钮的样式data-message:它控制我们发送到下一轮的消息。


五、技术解决方案架构


自定义输出格式技术在智能对话系统中的应用,犹如为智能对话注入了一剂强心剂,使其从传统的单向文本交互跃升至多维度、个性化的交互新时代。通过对业务场景的深入剖析、解决方案的精准制定以及操作步骤的详细解读,我们得以洞察这一技术的强大魅力与实用价值。从会话变量节点的设置到直接回复节点的输出,每一个环节都紧密相连、环环相扣,共同构建起一个高效、智能的对话架构。

53AI,企业落地大模型首选服务商

产品:场景落地咨询+大模型应用平台+行业解决方案

承诺:免费场景POC验证,效果验证后签署服务协议。零风险落地应用大模型,已交付160+中大型企业

联系我们

售前咨询
186 6662 7370
预约演示
185 8882 0121

微信扫码

添加专属顾问

回到顶部

加载中...

扫码咨询