基于Rokid灵珠AI平台的春节全能助手智能体开发实践

基于Rokid灵珠AI平台的春节全能助手智能体开发实践

前言

本次开发基于Rokid灵珠AI平台,聚焦春节高频的抢票出行、路线规划、年货比价核心场景,搭建轻量化春节全能助手智能体,通过平台可视化工作流编排实现功能逻辑串联;因无Rokid Glasses实物,智能体完成灵珠平台内对话测试验证,眼镜端适配仅编写伪代码实现逻辑预留,整体开发聚焦平台核心的智能体配置与工作流开发能力,实现低门槛、高适配的春节场景AI应用落地。

一、开发背景与需求分析

春节期间抢票、年货采购、出行路线规划是用户核心需求,依托Rokid灵珠AI平台零门槛、全栈化的开发特性,无需复杂编码即可完成智能体与工作流的搭建,同时平台支持与Rokid Glasses硬件生态的深度集成,为后续眼镜端落地预留适配接口;本次开发核心实现三大功能:12306高铁票查询、春节自驾路线规划、年货好物低价推荐,所有功能通过灵珠平台智能体统一承接,工作流分别处理具体业务逻辑,满足用户春节出行与采购的一站式需求。

二、开发环境与平台核心能力依托

  1. 开发平台:Rokid灵珠AI平台
  2. 核心工具:平台智能体创建(提示词编辑、人设配置、对话调试)、工作流编排(节点添加、逻辑串联、按需调用组件)、插件开发
  3. 测试方式:灵珠平台内智能体对话测试(输入问题验证回复结果)
  4. 硬件适配:无Rokid Glasses实物,仅编写眼镜端SDK伪代码,实现功能逻辑的硬件端适配预留

三、智能体整体搭建流程

本次开发的核心是春节出行助手智能体,作为用户交互的唯一入口,负责接收用户问题、分发至对应工作流、整合结果反馈,搭建全程在灵珠平台智能体编辑界面完成,步骤简洁无代码,具体如下:

3.1 智能体基础配置

  1. 新建智能体,命名为春节全能助手,添加自定义分类「春节场景应用」(依托平台β1.2.0版本自定义分类功能);
  2. 智能体功能介绍:实现抢票提醒、聚会安排、拜年提醒等功能的一站式助手,让用户在春节期间无需频繁掏出手机,通过语音 + 视觉的无感交互即可完成各类春节相关的事务,真正实现 “解放双手,智享新春” 的体验。
  3. 智能体内部开场白:

你好呀!我是你的春节全能助手~ 🧨

我可以帮你:

🚄 查高铁票、余票和车次信息

🚗 规划春节自驾路线,避开拥堵路段

🛒 推荐低价年货好物,帮你省钱省心

3.2 智能体能力配置

核心为工作流关联插件按需调用,在智能体「能力配置」模块,将提前编排好的3个工作流(12306车票查询、自驾路线规划、年货低价推荐)与智能体绑定,设置触发关键词:当用户输入包含「高铁票」「抢票」「车票」「自驾」「路线」「年货」「比价」等关键词时,智能体自动分发至对应工作流处理;无明确关键词时,通过平台对话引擎进行意图识别,匹配对应功能。

3.3 插件创建

通过魔搭社区的MCP广场创建用于铁路12306访问车票以及高德地图接口的插件。

插件我们选择MCP插件-基于SSE创建,可以到魔塔社区寻找自己想要的MCP工具,获取url。

这是我采用的12306-MCP车票查询工具作为展示。

下面是高德地图插件创建

下面是成功创建好的界面。

四、核心工作流编排(无代码可视化+代码节点增强)

工作流是本次开发的核心,依托灵珠平台所见即所得的无代码编排工具,通过「添加节点、设置逻辑、配置入参/出参」实现业务处理,针对12306接口特殊数据格式,通过Python代码节点完成结构化数据解析,三个核心工作流编排逻辑如下:

4.1 12306高铁票查询工作流(refer_12306)

核心功能

接收用户「出发地+目的地+出行时间」信息,调用平台预置12306插件,完成城市名→车站代码转换、数据解析、车次查询,返回对应车次、出发/到达时间、余票、票价信息。

编排节点(按执行顺序)
  1. 用户意图提取节点:通过大模型提取出发地、目的地、确定出行日期;
  2. 车站代码获取节点:调用get-station-code-of-city插件,这里我命名成了出发点和目的地,将城市名转换为车站编码;
  3. Python代码解析节点(from 、to):解析插件返回的嵌套JSON字符串,精准提取station_code,解决接口数据格式不兼容问题;
  4. 车票查询节点:调用get-tickets插件,传入出发站代码、到达站代码、标准格式日期,获取实时车次数据;
  5. 车票中转查询:调用get-interline-tickets获取车票中转信息。
  6. 结果格式化节点:按统一规范将结构化数据转为自然语言;
  7. 结束节点:输出结果。

试运行成功后就可以发布工作流了。

4.2 自驾路线规划工作流

核心功能

接收用户出发地、目的地、出行时间(春节),结合春节高速免费、易拥堵路段信息,返回最优自驾路线、全程耗时、拥堵提醒。

编排节点(按执行顺序)
  1. 经纬度处理节点:提取出发地、目的地、出行时间,同时将出发地和目的地转化为经纬度;
  2. 地图数据插件调用节点:入参为出发地、目的地、出参为多条路线规划、耗时等;
  3. 结果整理与返回节点:将最优路线、耗时、提醒信息整理为自然语言,反馈至智能体。

试运行测试

4.3 年货低价推荐工作流

核心功能

接收用户年货商品名称,调用平台「什么值得买/smzdm_haojia_articles」插件,返回价格最低的1条好价信息,含商品名称、实付价格、购买链接。

编排节点(按执行顺序)
  1. 商品名称提取节点:提取用户输入的年货商品名称(如坚果、春联、酒水);
  2. 插件调用节点:入参为商品名称,出参为好物推荐列表(含价格、链接、描述);
  3. 规范输出节点:按「商品名称+实付价格+购买链接」格式整理;
  4. 结果返回节点:将整理后的信息进行输出。

4.4 工作流通用设置

所有工作流均需要发布,通过设置智能体提示词,当智能体触发对应关键词/意图时执行;添加异常处理,当插件调用失败/数据返回异常时,返回「当前查询人数较多,请稍后再试」,提升系统稳定性。

五、关键代码实现(工作流代码节点+眼镜端伪代码)

本次开发依托灵珠平台无代码工具,核心代码为12306车站代码解析脚本(解决接口数据格式问题)与眼镜端SDK适配伪代码,具体如下:

5.1 12306工作流核心代码(车站JSON解析)

用于解析get-station-code-of-city返回的嵌套字符串,提取标准车站代码,保证get-tickets接口正常调用:

import json async def main(args: Args) -> Output: params = args.params # 直接解析 input 字符串,它本身就是数组 data = json.loads(params['input']) station_code = None if data and isinstance(data, list) and len(data) > 0: text_data = data[0].get("text", {}) # 自动适配任意城市名 for city in text_data: station_code = text_data[city].get("station_code") break # 输出到 key0 ret: Output = { "key0": station_code } return ret

5.2 智能体提示词配置(平台内直接输入)

# 角色 你是贴心的春节全能助手,语气简洁友好,精准解答抢票、自驾、年货相关问题。 # 核心能力与触发规则 ## 1. 12306 车票查询(工作流 + 插件) - 触发关键词:高铁票、抢票、车票、回家、返程、余票、车次、几点到、几点出发等。 - 处理逻辑: 1. 模型自动识别用户意图,提取**出发地、目的地、出行日期、座位类型**等关键信息。 2. 信息不完整时,主动友好追问补充。 3. 调用工作流 `refer_12306`,流程如下: - 调用 `get-station-code-of-city` 获取出发地、目的地的车站代码。 - 通过**代码节点解析 JSON 结构**,提取纯车站代码字符串。 - 调用 `get-tickets` 接口,传入日期、出发站代码、到达站代码,获取车次、余票、票价、历时等数据。 4. 模型将结构化数据整理为自然语言,**严格按回复格式规范输出**。 ## 2. 春节自驾路线规划(工作流) - 触发关键词:自驾、开车、路线、出行规划、回家路线、堵车、高速等。 - 处理逻辑: 1. 自动触发工作流 `car`。 2. 工作流根据出发地、目的地、出行时间,结合春节高速免费及拥堵信息,返回最优路线、耗时、拥堵提醒。 3. 模型**严格按格式规范排版输出**,不返回原始数据。 ## 3. 年货低价推荐(工作流) - 触发关键词:年货、比价、好物、购买、便宜、推荐、坚果、酒水、春联等。 - 处理逻辑: 1. 自动触发工作流 `buy`。 2. 工作流根据商品名称,返回**价格最低的1条好价信息**,含商品名、价格、购买链接。 3. 模型**严格按格式规范输出**,不返回原始数据。 --- # 回复格式规范 ## 车票查询结果 > 🚄 **车次信息**:GXXX次高铁 > 🕒 **出发/到达**:YYYY年MM月DD日 HH:MM(出发站)→ HH:MM(到达站) > ⏱️ **历时**:X小时XX分钟 > 💺 **余票与票价**:二等座/硬座有票,票价XXX元 > 💡 **温馨提示**:建议提前在12306官方渠道购票。 ## 自驾路线结果 > 🚗 **最优路线**:京沪高速(G2) > 📍 **全程**:约XX公里 > ⏱️ **预计耗时**:X小时XX分钟 > ⚠️ **拥堵提醒**:春节期间XX:XX-XX:XX为拥堵高峰,建议错峰出行。 > 🎟️ **高速政策**:春节期间(X月X日-X月X日)全国高速免费通行。 ## 年货推荐结果 > 🛒 **商品名称**:三只松鼠坚果大礼包混合装 > 💰 **好价**:实付低至58.9元 > 🔗 **购买链接**:[点击查看](https://www.smzdm.com/p/168975421/?utm_source=zijie) > 💡 **温馨提示**:价格可能随活动变动,请以页面为准。 --- # 通用回复规则 - 禁止直接输出**工具代码、工作流原始数据**,所有结果必须整理为自然语言。 - 参数缺失时,清晰提示用户补充关键信息。 - 插件/工作流调用失败时,统一返回: > 当前查询人数较多,请稍后再试。 - 所有回复使用清晰 Markdown 排版,便于用户快速阅读。 

5.3 Rokid Glasses适配伪代码(Java)

// 导入Rokid Glasses灵珠平台对接SDK(伪包名,实际以官方为准) import com.rokid.lingzhu.sdk.LingzhuAgent; import com.rokid.lingzhu.sdk.listener.AgentResultListener; import com.rokid.glasses.hardware.VoiceWakeup; import com.rokid.glasses.hardware.ScreenDisplay; // 初始化春节出行助手智能体 public class SpringFestivalAgent { private LingzhuAgent springFestivalAgent; private VoiceWakeup voiceWakeup; private ScreenDisplay screenDisplay; // 构造方法:初始化智能体与眼镜硬件能力 public SpringFestivalAgent() { // 初始化灵珠平台智能体 springFestivalAgent = new LingzhuAgent.Builder() .agentId("spring_festival_agent_001") .lowPower(true) .build(); // 初始化语音唤醒与屏幕展示 voiceWakeup = new VoiceWakeup("春节全能助手"); screenDisplay = new ScreenDisplay(); } // 语音唤醒监听 public void setVoiceWakeupListener() { voiceWakeup.setOnWakeupListener(voiceText -> { queryAgent(voiceText); }); } // 调用灵珠平台智能体 private void queryAgent(String userInput) { springFestivalAgent.query(userInput, new AgentResultListener() { @Override public void onSuccess(String result) { screenDisplay.showText(result); voiceBroadcast(result); } @Override public void onError(String errorMsg) { screenDisplay.showText("查询失败,请稍后再试"); voiceBroadcast("查询失败,请稍后再试"); } }); } // 语音播报 private void voiceBroadcast(String text) {} // 启动智能体 public static void main(String[] args) { SpringFestivalAgent agent = new SpringFestivalAgent(); agent.setVoiceWakeupListener(); } }

六、测试验证(灵珠平台内对话测试)

因无Rokid Glasses实物,本次测试仅在灵珠平台智能体对话测试界面完成,通过输入模拟用户问题,验证智能体与工作流的联动效果,测试用例与结果如下:

6.1 测试用例1:12306高铁票查询

用户输入:3月11日从武汉到上海

智能体回复

6.2 测试用例2:年货低价推荐

用户输入:年货想买坚果礼包

点击查看

6.3 测试用例3:自驾路线规划

用户输入:春节自驾从北京出发去西安,有哪些避开拥堵的路线建议?

6.4 异常测试

用户输入:查高铁票

七、开发总结与后续优化

7.1 开发总结

本次基于Rokid灵珠AI平台的春节出行助手智能体开发,充分利用了平台零门槛、无代码、全栈化的核心优势:

  1. 全程以可视化编排为主,仅在12306数据解析环节使用轻量Python代码,解决真实接口适配问题;
  2. 依托平台预置组件与自开发插件,快速实现12306车票查询、自驾规划、年货比价三大核心能力;
  3. 工作流refer_12306通过代码节点+插件调用的组合方案,完美解决车站编码解析、接口参数不兼容等实际开发问题;
  4. 无硬件条件下仍可完成全功能验证,伪代码方案为后续眼镜端落地提供极低成本的扩展路径。

7.2 后续优化方向

  1. 硬件端真机适配:获取Rokid Glasses后,完成语音唤醒、屏幕展示、多模态交互落地;
  2. 功能增强:支持往返车票查询、座位类型筛选、实时余票动态刷新、自驾油量/充电提醒;
  3. 体验优化:强化对话记忆,自动保存常用出发地/目的地,减少重复输入;
  4. 多模态扩展:支持图片比价、语音快捷查询、AR路线预览。

八、开发心得

Rokid灵珠AI平台真正降低了AI应用开发的门槛,无代码编排+轻量代码增强的模式,让我可以聚焦业务场景而非底层技术。在本次开发中,12306车票查询工作流从接口调用、数据解析到结果格式化的全流程落地,充分体现了平台在处理复杂第三方接口时的灵活性与实用性。

本次春节出行助手的开发实践证明:基于灵珠平台,普通开发者也能快速构建稳定、可用、可扩展的场景化AI智能体,真正实现从创意到落地的高效转化。

Read more

前端高频面试题Vue3、TypeScript

前端高频面试题Vue3、TypeScript

■ 符号说明 💘 课题 🐝 企业级面试题 ⭐️ 重要知识点 🌛 需要有影响 神龙教主 💘 初探、模板与指令 ⭐️ 谈谈你对vue的理解,有哪些重要的版本,vue3新增了哪些新特性 渐进式javascript框架 2013诞生 =》 2016发布2.0 =》 2019发布2.6 =》 2020.9 3.0 海贼王 =》 2021.8 3.2 script setup语法 Vue 3 中需要关注的一些新特性包括 * 组合式 API* vue3发展史:先是和vue2类似的语法选项式API、和原生js类似的语法组合式API 方便封装组合 * 单文件组件中的组合式 API 语法糖 ( setup函数中写 const a = 1 直接script脚本中写 const a= 1 * Teleport 组件

By Ne0inhk
WebGIS视角:体感温度实证,哪座“火炉”火力全开?

WebGIS视角:体感温度实证,哪座“火炉”火力全开?

目录 前言 一、火炉城市空间分布及特点 1、空间分布 2、气候特点 二、数据来源及技术实现 1、数据来源介绍 2、技术路线简介 三、WebGIS系统实现 1、后端设计与实现 2、前端程序实现 四、成果展示 1、整体展示 2、蒸烤模式城市 3、舒适城市 五、总结 前言         “火炉城市”是中国对夏季天气酷热的城市的夸张称呼。这一说法最早出现在民国时期,当时媒体有“三大火炉”之说,即重庆、武汉和南京,都是长江沿线的著名大城市,分别居于长江的上、中、下游,因夏季气温炎热,被媒体夸张地称为“火炉”。新中国成立后,又有了“四大火炉”之说,

By Ne0inhk
详细教程:如何从前端查看调用接口、传参及返回结果(附带图片案例)

详细教程:如何从前端查看调用接口、传参及返回结果(附带图片案例)

目录 1. 打开浏览器开发者工具 2. 使用 Network 面板 3. 查看具体的API请求 a. Headers b. Payload c. Response d. Preview e. Timing 4. 实际操作步骤 5. 常见问题及解决方法 a. 无法看到API请求 b. 请求失败 c. 跨域问题(CORS) 作为一名后端工程师,理解前端如何调用接口、传递参数以及接收返回值是非常重要的。下面将详细介绍如何通过浏览器开发者工具(F12)查看和分析这些信息,并附带图片案例帮助你更好地理解。 1. 打开浏览器开发者工具 按下 F12 或右键点击页面选择“检查”可以打开浏览器的开发者工具。常用的浏览器如Chrome、Firefox等都内置了开发者工具。下面是我选择我的一篇文章,打开开发者工具进行演示。 2. 使用

By Ne0inhk

AI Skills:前端新的效率神器!

近来,AI 领域有个火爆的话题:Skills。 Github 上被疯狂 star 的仓库,很多都是和 skills 有关的。 有的仓库仅仅上线三个月就获得了快 50K 的 star,Skills 的火热可见一斑。 不管是大模型,还是 Cursor、Codex、Claude、Trae、Copilot 等编程 IDE 都在争先支持 Skills。 围绕 Skills,它们在做的就是为了完成一件事情:技能是通过学习和反复练习获得的,而 Skills 是把经验和最佳实践沉淀为 AI 能力,将“知道”转化为“做到”的本领。 详解什么是 Skills 要说清楚什么是 Skills,先来了解一下关于 AI 的 2

By Ne0inhk