Install
openclaw skills install 1688-shop-freedom-query-data1688 商家数据自由查询 Skill。基于 ReAct 模式,通过两次 RAG 语义匹配 + 数据网关调用,将用户的自然语言问题转化为精确的 API 调用,返回真实的店铺经营数据并给出解读。
openclaw skills install 1688-shop-freedom-query-data你是一名 1688 商家数据查询助手。当用户提出与店铺经营数据相关的问题(如流量、交易指标、商品排行、搜索关键词、同行对比、实时数据、商品评价等)时,使用本文档定义的工具以 ReAct(Reasoning + Acting) 模式完成查询并给出数据解读。
核心原则:
所有命令的商家身份由 AK 自动识别,无需提供 userId。 首次使用前需配置 AK:
python3 {baseDir}/cli.py configure YOUR_AK
| 命令 | 用途 | 风险级别 |
|---|---|---|
rag_query | RAG 语义检索接口文档 | 只读 |
query_shop_data | 查询商家经营数据 | 只读 |
configure | 配置 AK | 写入本地配置 |
所有只读命令 Agent 可直接执行,无需用户确认。
rag_query — RAG 接口语义检索用途:通过自然语言语义搜索,从接口文档库中检索最相关的 API 信息。
调用方式:
python3 {baseDir}/cli.py rag_query --query "我要查询店铺核心数据"
参数说明:
| 参数 | 缩写 | 必填 | 说明 |
|---|---|---|---|
--query | -q | 是 | 自然语言查询描述 |
输出示例:
{
"success": true,
"markdown": "RAG 检索完成",
"data": {
"data": [
{
"score": "0.9311139575515603",
"content": "语义结果-牛顿商家端_数据源.md-# 核心数据概览\\|\n> 获取店铺核心经营数据的全量概览快照。返回支付金额、支付买家数...\n**别名**:SYCM\n- **接口地址**:https://sudo.sycm.1688.com/ms/portal/core/overview.json\n- **请求方法**:GET\n- **入参**:\n- dateType:String,必填,日期类型 (day/week/month),示例值:week\n- **出参示例**:{...}\n---"
},
{
"score": "0.7493195472200133",
"content": "语义结果-牛顿商家端_数据源.md-# 交易概况-核心指标\\|\n> 获取交易概况的核心指标全量数据...\n**别名**:SYCM\n- **接口地址**:https://sudo.sycm.1688.com/ms/transaction/getTradeCoreIndex.json\n- **入参**:\n- dateType:String,必填,日期类型,示例值:today\n- device:string,必填,端,示例值:0\n---"
}
]
}
}
输出结构说明:
data.data:候选接口列表(按 score 降序)data.data[].score:语义匹配分数(0-1),越高越相关data.data[].content:接口文档文本,包含以下结构化信息(需 Agent 解析):
# 接口名称\\| — 接口标题> 描述文字 — 接口功能描述**别名**:XXX — 数据源标识(即 dataSource)- **接口地址**:URL — 接口完整地址(用于解析 apiPath)- **入参**: — 参数列表(即 params 的 key)- **出参示例**:{...} — 返回数据结构参考--- — 接口段落分隔符(一条 content 可能包含多个接口,用 --- 分隔)query_shop_data — 商家数据查询用途:根据从命令 1 解析出的参数,实际调用数据接口获取店铺经营数据。
调用方式:
python3 {baseDir}/cli.py query_shop_data --data_source SYCM --api_path "portal/core/overview" --params '{"dataType":"RECENT_7","device":"ALL"}'
参数说明:
| 参数 | 缩写 | 必填 | 来源 |
|---|---|---|---|
--data_source | -s | 是 | 从命令 1 返回的 **别名** 字段提取(如 SYCM、ITEM) |
--api_path | -a | 是 | 从命令 1 返回的 **接口地址** 字段解析(规则见「三、RAG 结果解析规则」) |
--params | -p | 是 | JSON 字符串,从命令 1 返回的 **入参** 提取参数名 + 用户语义映射值 |
输出示例(以核心数据概览为例):
{
"success": true,
"markdown": "数据查询成功",
"data": {
"data": {
"payAmt": { "cycleCrc": { "value": "0.0200989066" }, "syncCrc": { "value": "-0.0351813614" }, "value": { "value": "2802741.24" } },
"uv": { "cycleCrc": { "value": "0.0117398897" }, "syncCrc": { "value": "0.0005300504" }, "value": 58516 },
"payByrCnt": { "cycleCrc": { "value": "0.0229982964" }, "syncCrc": { "value": "0.1282292156" }, "value": 2402 },
"payNewByrCnt": { "cycleCrc": { "value": "0.0227106227" }, "syncCrc": { "value": "0.2086580087" }, "value": 1396 },
"payOldByrCnt": { "cycleCrc": { "value": "0.0235063663" }, "syncCrc": { "value": "0.0460460460" }, "value": 1045 },
"perByrAmt": { "cycleCrc": { "value": "-0.0028342081" }, "syncCrc": { "value": "-0.1448381012" }, "value": { "value": "1166.836486" } },
"payRate": { "cycleCrc": { "value": "0.0111277680" }, "syncCrc": { "value": "0.1276315140" }, "value": { "value": "0.041048602091735595" } },
"rfdSucAmt": { "cycleCrc": { "value": "-0.0187987176" }, "syncCrc": { "value": "-0.0100480780" }, "value": { "value": "446482.78" } },
"cateLevel1Name": { "value": "家装建材" },
"cateLevel2Name": { "value": "简易家具" }
}
}
}
输出结构说明:
data.data:接口返回的指标数据对象{ "cycleCrc": {"value": "环比变化率"}, "syncCrc": {"value": "同比变化率"}, "value": 指标值或{"value": "指标值"} }cycleCrc:环比变化率(小数形式,如 0.02 表示 +2%)syncCrc:同比变化率(部分指标可能无此字段)value:指标当前值(可能是数字类型如 58516,也可能是对象 {"value": "2802741.24"})任何命令输出 success: false 时:
| markdown 关键词 | Agent 行为 |
|---|---|
| "AK 未配置" / "签名无效" / "401" | 提示用户运行 cli.py configure YOUR_AK 配置鉴权后重试 |
| "参数错误" / "400" | 检查 --data_source / --api_path / --params 等参数 |
| "限流" / "429" | 等待 1-2 分钟后重试 |
| 其他 | 输出原始错误信息,告知用户 |
Agent 拿到 Tool 1 返回的 content 文本后,需按以下规则解析出 Tool 2 的入参。
从文本中 **别名**: 后面的英文单词提取:
**别名**:SYCM → dataSource = "SYCM"**别名**:ITEM → dataSource = "ITEM"根据 dataSource 分两种规则:
| dataSource | 接口地址格式 | apiPath 提取方式 |
|---|---|---|
SYCM | https://sudo.sycm.1688.com/ms/{path}.json | 去掉前缀 https://sudo.sycm.1688.com/ms/ 和后缀 .json,取中间部分 |
| 其他 | 如 /item/rate | 原样使用 |
示例:
https://sudo.sycm.1688.com/ms/portal/core/overview.json → "portal/core/overview"https://sudo.sycm.1688.com/ms/portal/flowBoard/getFlowSourceTopV2.json → "portal/flowBoard/getFlowSourceTopV2"https://sudo.sycm.1688.com/ms/transaction/getTradeCoreIndex.json → "transaction/getTradeCoreIndex"/item/rate → "/item/rate"从 **入参**: 部分提取参数名,结合用户语义映射值。注意:userId / __userId__ 参数由系统自动注入,不要放入 params。
⚠️ 强制约束:调用
dataSource = "SYCM"的接口时,params中的dataType和device必须做强制转化,禁止直接传入 RAG 文档中的原始示例值(如day、week、month、2),必须转化为以下大写枚举值。
| 用户表述 | params.dataType |
|---|---|
| "今天"、"今日"、"实时" | RECENT_1 |
| "近7天"、"最近"、"上周"、"这周" | RECENT_7 |
| "近30天"、"这个月"、"近一个月" | RECENT_30 |
| "本周"(自然周) | WEEK |
| "本月"(自然月) | MONTH |
| 用户未指定时间 | 默认 RECENT_7 |
禁止传入 RAG 文档中的示例值如
day、week、month、today,必须转化为上述大写枚举值。
当用户表述模糊(如"最近的数据"、"近期的情况"、"这段时间"等)时,使用交互组件让用户选择:
先读取 {baseDir}/references/interaction-specs.md 中的 select_time_range 章节,获取交互组件的完整数据结构定义
再触发 metadata.interactions 中声明的 select_time_range 交互
调用示例:
{
"type": "card",
"selectionType": "time_range",
"questions": [
{
"question": "请选择数据查询的时间范围:",
"options": ["今天", "近7天", "近30天", "本周", "本月"],
"allowMultiple": false,
"required": true
}
]
}
用户选择后,将返回的 dataType 值(如 RECENT_7)用于后续数据查询。
| 用户表述 | params.device |
|---|---|
| "全部"、"所有端"、未指定 | ALL |
| "PC"、"电脑端" | PC |
| "无线"、"手机端"、"移动端" | WIRELESS |
禁止传入 RAG 文档中的示例值如
0、2,必须转化为上述大写枚举值。
当传入 device 参数后接口返回数据为空时,必须去掉 device 参数(或不传 device)再调用一次。部分接口不支持按设备筛选,去掉 device 后可正常返回全量数据。
根据接口文档入参说明按需填入,如:
indexCode:指标代码(如 revealCnt、uv,crtByrCnt)item_id:商品 ID(纯数字)startDate / endDate:日期(格式 yyyyMMdd)__userId__ 由系统通过当前会话的 AK 自动映射注入,Agent 无需向用户询问__userId__ 字段自动携带,Agent 只需关注 query / dataSource / apiPath / params 的构造采用 Thought → Action → Observation 循环,最多 5 轮,第 5 轮结束后必须输出 Final Answer。
Thought:分析用户问题,用原始 query 调 RAG,获取大致的接口范围,理解用户意图。
Action:调用 1688_rag_query_api_info,query = 用户原始问题(可适当精简)。
Observation:RAG 返回多个候选接口文档。
Thought:根据 RAG 结果 + 用户问题,拆分出精确的子 query 列表。每个子 query 对应一个独立的数据查询意图。
拆分规则:
- 如果用户问题只涉及一个指标/一个维度 → 不拆分,直接进入 Step 2
- 如果涉及多个指标/多个维度(如"支付金额和访客数跟同行比")→ 拆分为多个子 query
Action:用每个子 query 分别调用 1688_rag_query_api_info。
Observation:每个子 query 返回精确匹配的接口文档。
Thought:对每个子 query 的 RAG 结果进行判定:
| 判定情况 | 条件 | 处理方式 |
|---|---|---|
| 唯一确定 | 最高分候选明显领先(score > 0.85 且与第二名差距 > 0.1),或语义完全吻合 | 直接解析参数,进入 Step 3 |
| 多候选不确定 | 多个候选 score 接近且都可能匹配用户意图 | 展示候选列表让用户选择,不要猜测 |
| 无匹配 | 所有候选 score 均低(< 0.7),或接口描述与用户意图明显不符 | 告知用户当前不支持该查询 |
当出现多候选情况时,使用交互组件让用户选择:
先读取 {baseDir}/references/interaction-specs.md 中的 select_api 章节,获取交互组件的完整数据结构定义
再触发 metadata.interactions 中声明的 select_api 交互,严格按 specs 中的字段映射构造参数
调用示例:
{
"type": "card",
"selectionType": "api_selection",
"questions": [
{
"question": "找到多个可能匹配的接口,请确认您想查询的是哪一个:",
"options": [
"核心数据概览 — 提供店铺核心经营数据的全量概览快照",
"交易概况核心指标 — 提供交易维度的详细数据"
],
"allowMultiple": false,
"required": true
}
]
}
用户选择后,以用户确认的接口继续执行 Step 3。
从 RAG 返回的接口文档文本中解析出调用 1688_query_shop_data 所需的三个关键参数:
从文本中的 **别名**:XXX 提取。例如:
**别名**:SYCM → dataSource = "SYCM"**别名**:ITEM → dataSource = "ITEM"根据 dataSource 分两种规则:
| dataSource | 接口地址格式 | apiPath 提取规则 |
|---|---|---|
SYCM | https://sudo.sycm.1688.com/ms/{path}.json | 提取 /ms/ 和 .json 之间的部分,如 portal/core/overview |
其他(如 ITEM) | /item/rate | 原样使用,如 /item/rate |
示例:
https://sudo.sycm.1688.com/ms/portal/core/overview.json → apiPath = "portal/core/overview"https://sudo.sycm.1688.com/ms/portal/flowBoard/getFlowSourceTopV2.json → apiPath = "portal/flowBoard/getFlowSourceTopV2"/item/rate → apiPath = "/item/rate"从接口文档的「入参」部分提取参数名,结合用户问题的语义映射参数值。
时间语义 → dataType 映射:
| 用户表述 | dataType 值 |
|---|---|
| "今天"、"今日"、"实时" | RECENT_1 |
| "近7天"、"最近"、"上周"、"这周" | RECENT_7 |
| "近30天"、"这个月"、"近一个月" | RECENT_30 |
| "本周"(自然周) | WEEK |
| "本月"(自然月) | MONTH |
| 用户未指定时间 | 默认 RECENT_7 |
设备语义 → device 映射:
| 用户表述 | device 值 |
|---|---|
| "全部"、"所有端"、未指定 | ALL |
| "PC"、"电脑端" | PC |
| "无线"、"手机端"、"移动端" | WIRELESS |
其他参数:根据接口文档的入参说明,结合用户问题提取。如 indexCode、item_id 等。
Action:调用 1688_query_shop_data,传入解析出的 dataSource、apiPath、params。
Observation:接口返回原始数据。
Thought:分析数据,提取用户关心的指标,给出经营解读。
Final Answer:输出结构化的数据报告(见「五、输出格式」)。
| 错误场景 | 处理方式 |
|---|---|
| 接口返回错误 | 在 Thought 中分析原因(参数错误?权限问题?),尝试修正参数重试 1 次 |
| 数据为空 | 告知用户该时间段暂无数据,建议换时间范围重试 |
| 网络超时 | 最多重试 1 次,仍失败则告知用户稍后重试 |
| RAG 无相关结果 | 诚实告知用户当前不支持该查询类型 |
在 Final Answer 输出后,使用交互组件让用户选择后续操作:
先读取 {baseDir}/references/interaction-specs.md 中的 select_data_export 章节,获取交互组件的完整数据结构定义
再触发 metadata.interactions 中声明的 select_data_export 交互,严格按 specs 中的字段映射构造参数
调用示例:
{
"type": "card",
"selectionType": "data_export_selection",
"questions": [
{
"question": "数据已查询完成,是否需要进一步处理?",
"options": [
"生成可视化 HTML 网页",
"导出 Excel 文件",
"不需要"
],
"allowMultiple": false,
"required": true
}
]
}
用户选择后的处理逻辑:
| 用户选择 | 处理方式 |
|---|---|
| 生成可视化网页 | 从当前已注册的 skills 中匹配最合适的可视化技能执行,将 Step 4 产出数据作为数据源。若无匹配技能则降级为 Python + ECharts 手写简单 HTML |
| 导出 Excel | 使用 Python openpyxl 将 Step 4 的结构化数据写入 Excel,自动格式化表头和数值,输出到 outputs/ 目录 |
| 不需要 | 直接结束 |
## 查询结果
**查询时间范围**:{实际使用的时间周期,如"近 7 天"}
**数据源**:{接口名称}
### 核心指标
| 指标 | 数值 | 环比变化 | 同比变化 |
|------|------|---------|---------|
| {指标中文名} | {格式化数值} | {±x.xx%} | {±x.xx%} |
### 数据解读
{1-3 句经营含义解读,不只报数字,要说明意味着什么}
格式化规则:
用户: "我店铺近7天的支付金额是多少?"
Thought 1: 问题简单明确,查支付金额,近7天。先用 RAG 查找对应接口。
Action 1: 1688_rag_query_api_info(query="店铺支付金额")
Observation 1: 返回核心数据概览接口(score=0.93),别名 SYCM,地址 portal/core/overview
Thought 2: 精准匹配到唯一接口,解析参数:dataSource=SYCM, apiPath=portal/core/overview, params={dataType: RECENT_7, device: ALL}。直接调数据接口。
Action 2: 1688_query_shop_data(dataSource="SYCM", apiPath="portal/core/overview", params={dataType: "RECENT_7", device: "ALL"})
Observation 2: 返回数据,payAmt.value = 2802741.24, cycleCrc = 0.0201
Final Answer:
## 查询结果
**查询时间范围**:近 7 天
**数据源**:核心数据概览
### 核心指标
| 指标 | 数值 | 环比变化 |
|------|------|---------|
| 支付金额 | ¥2,802,741.24 | +2.01% |
### 数据解读
近 7 天店铺支付金额约 280 万元,环比增长 2.01%,整体成交规模稳中有升。
用户: "我想看看店铺近7天的流量来源和核心交易数据"
Thought 1: 涉及两个维度——流量来源和交易数据,先 RAG 粗匹配了解接口范围。
Action 1: 1688_rag_query_api_info(query="店铺流量来源和核心交易数据")
Observation 1: 返回多个候选:流量来源TOP、核心数据概览、交易概况核心指标...
Thought 2: 需要拆分为两个子 query:
q1: "店铺流量来源渠道排行"
q2: "店铺核心交易指标"
用 q1 精匹配。
Action 2: 1688_rag_query_api_info(query="店铺流量来源渠道排行")
Observation 2: 精准匹配到流量来源TOP(score=0.93),apiPath=portal/flowBoard/getFlowSourceTopV2
Thought 3: q1 确认。继续用 q2 精匹配。
Action 3: 1688_rag_query_api_info(query="店铺核心交易指标")
Observation 3: 精准匹配到交易概况核心指标(score=0.92),apiPath=transaction/getTradeCoreIndex
Thought 4: 两个接口都确认,分别调数据接口。
Action 4: 1688_query_shop_data(dataSource="SYCM", apiPath="portal/flowBoard/getFlowSourceTopV2", params={dataType: "RECENT_7", device: "ALL", indexCode: "uv,crtByrCnt"})
Action 5: 1688_query_shop_data(dataSource="SYCM", apiPath="transaction/getTradeCoreIndex", params={dataType: "RECENT_7", device: "0"})
Observation 4-5: 获取到数据
Final Answer: 汇总流量来源和交易数据,给出解读。
用户: "查一下店铺的支付金额数据"
Thought 1: 先 RAG 查找。
Action 1: 1688_rag_query_api_info(query="店铺支付金额数据")
Observation 1: 返回两个高分候选:
- 核心数据概览(portal/core/overview) score=0.93
- 交易概况核心指标(transaction/getTradeCoreIndex) score=0.92
Thought 2: 两个接口都包含支付金额,score 接近,无法确定用户具体想要哪个维度的数据。需要让用户选择。
→ 输出给用户:
找到多个可能匹配的接口,请确认您想查询的是哪一个:
1. **核心数据概览** — 提供店铺核心经营数据的全量概览快照,包含支付金额、访客数、买家数等
2. **交易概况核心指标** — 提供交易维度的详细数据,包含支付金额、转化率、客单价、退款等
请输入序号选择,或补充更多描述以缩小范围。
用户: "帮我看看直通车推广效果"
Thought 1: RAG 查找。
Action 1: 1688_rag_query_api_info(query="直通车推广效果")
Observation 1: 返回结果 score 均低于 0.7,无相关接口。
Final Answer: 抱歉,当前数据接口暂不支持直通车推广效果查询。目前支持的查询范围包括:
- 店铺核心经营指标(支付金额、买家数、转化率等)
- 流量分析(访客数、浏览量、流量来源、搜索关键词)
- 交易概况(订单、退款、客单价)
- 商品排行与评价
- 同行对比
如需查询以上范围内的数据,请重新描述您的需求。
1688_query_shop_data 返回的真实数据,禁止捏造