2026-03-27 17:42:41 +08:00
# 腾讯文档 MCP 工具完整参考
本文件包含腾讯文档 MCP 所有工具的通用 API 说明、详细调用示例、参数说明和返回值说明。
---
## 通用说明
### 响应结构
所有 API 返回都包含:
- `error` : 错误信息(成功时为空)
- `trace_id` : 调用链追踪 ID
### node_type 枚举值
| 值 | 说明 |
|---|---|
| wiki_folder | 文件夹 |
| wiki_tdoc | 在线文档(请求时使用) |
| wiki_file | 在线文档(返回值中使用) |
| link | 链接 |
| resource | 资源文件 |
### doc_type 枚举值
| 值 | 说明 |
|---|---|
| word | 文字处理文档 |
| excel | 电子表格 |
| form | 收集表 |
| slide | 幻灯片 |
| smartcanvas | 智能文档 |
| smartsheet | 智能表格 |
| board | 白板 |
| mind | 思维导图 |
| flowchart | 流程图 |
### NodeInfo 节点信息结构
```json
{
"node_id": "节点 ID, 同时也是 file_id",
"title": "节点标题",
"node_type": "节点类型",
"has_child": true,
"doc_type": "文档类型(仅 wiki_file 有效)",
"url": "访问链接"
}
```
### StringMatrix 表格数据结构
```json
{
"texts": {
"rows": [
{"values": ["单元格1", "单元格2"]},
{"values": ["单元格3", "单元格4"]}
]
}
}
```
数据从 A1 单元格开始,按行列顺序填充。
### 分页说明
- `query_space_node` :每页 20 条
- `space_list` :每页 100 条
- 使用 `has_next` 判断是否有更多数据
- 页码从 0 开始
---
## 工具调用示例
## 1. create_smartcanvas_by_markdown
### 功能说明
通过 Markdown 格式创建智能文档,排版美观,支持所有 Markdown 基本结构。
### 调用示例
```json
{
"title": "项目需求文档",
"markdown": "# 项目需求\n\n## 项目背景\n\n本项目旨在开发一套智能文档管理系统...\n\n## 功能需求\n\n- 文档创建功能\n- 文档编辑功能\n- 协作功能\n\n## 技术架构\n\n| 组件 | 技术选型 |\n|------|----------|\n| 前端 | React |\n| 后端 | Go |\n| 数据库 | MySQL |",
"parent_id": "folder_1234567890"
}
```
### 参数说明
- `title` (string, 必填): 文档标题
- `markdown` (string, 必填): UTF-8 格式的 Markdown 文本
- `parent_id` (string, 可选): 父节点ID, 为空时在空间根目录创建, 不为空时在指定节点下创建
### 返回值说明
```json
{
"file_id": "doc_1234567890",
"url": "https://docs.qq.com/doc/DV2h5cWJ0R1lQb0lH",
"error": "",
"trace_id": "trace_1234567890"
}
```
## 2. create_excel_by_markdown
### 功能说明
通过 Markdown 表格创建 Excel, 适用于需要数据计算、筛选的场景。
### 调用示例
```json
{
"title": "销售数据报表",
"markdown": "| 日期 | 产品 | 销售额 | 销售量 |\n|------|------|--------|--------|\n| 2024-01-01 | 产品A | 10000 | 100 |\n| 2024-01-02 | 产品B | 15000 | 150 |",
"parent_id": "folder_1234567890"
}
```
### 参数说明
- `title` (string, 必填): 表格标题
- `markdown` (string, 必填): 包含表格的 Markdown 文本
- `parent_id` (string, 可选): 父节点ID, 为空时在空间根目录创建, 不为空时在指定节点下创建
### 返回值说明
```json
{
"file_id": "sheet_1234567890",
"url": "https://docs.qq.com/sheet/DV2h5cWJ0R1lQb0lH",
"error": "",
"trace_id": "trace_1234567890"
}
```
## 3. create_slide
### 功能说明
根据用户描述和参考资料,由 AI 自动生成幻灯片内容并创建 PPT。
### 调用示例
**示例1: 根据主题生成 PPT**
```json
{
"description": "生成一份主题为'2024年度销售总结'的PPT, 要求包含业绩回顾、亮点项目、问题分析和来年规划四个章节"
}
```
**示例2: 根据参考材料生成 PPT**
```json
{
"reference_context": "第一季度销售额达到1200万, 同比增长25%。主要增长来自华南区域, 新客户占比40%。存在问题:北方市场渗透率不足,客单价偏低。",
"description": "根据材料生成PPT, 要求风格简洁专业, 重点突出数据亮点"
}
```
### 参数说明
- `description` (string, 必填): 用户对 PPT 的要求描述。样例1: 【生成一份主题为xxx的PPT, 要求xxxx】; 样例2: 【根据材料生成PPT, 要求xxxx】
- `reference_context` (string, 可选): 生成 PPT 的参考资料,必须是 UTF-8 文本格式。**仅当用户明确指定需要根据某段内容/材料生成PPT时才传此参数, 不要自由发挥填充内容**
### 返回值说明
```json
{
"session_id": "session_1234567890",
"error": "",
"trace_id": "trace_1234567890"
}
```
> ⚠️ **注意**: `create_slide` 为异步接口,返回 `session_id` 后需配合 `slide_progress` 工具轮询进度( 每隔20秒轮询一次, 最长等待20分钟) , 待状态为 `completed` 时从响应中获取 `file_url`。
## 4. slide_progress
### 功能说明
查询幻灯片生成进度,与 `create_slide` 配合使用。调用 `create_slide` 获取 `session_id` 后,每隔 20 秒轮询一次,最长等待 20 分钟,直到状态为 `completed` 或 `failed` 。
### 状态说明
- `in_progress` :进行中,继续轮询
- `completed` :已完成,幻灯片已生成,从响应中获取 `file_url`
- `failed` :失败,停止轮询
- `canceled` :已取消,停止轮询
- `not_found` :未找到(`session_id` 不正确或已过期),停止轮询
### 调用示例
```json
{
"session_id": "session_1234567890"
}
```
### 参数说明
- `session_id` (string, 必填): `create_slide` 返回的异步任务 session_id
### 返回值说明
```json
{
"status": "completed",
"file_url": "https://docs.qq.com/slide/DV2h5cWJ0R1lQb0lH",
"error": "",
"trace_id": "trace_1234567890"
}
```
## 5. create_mind_by_markdown
### 功能说明
通过 Markdown 创建思维导图,使用标题层级和列表嵌套表示结构。
### 调用示例
```json
{
"title": "产品功能规划",
"markdown": "# 产品功能规划\n\n## 核心功能\n\n- 文档管理\n - 创建文档\n - 编辑文档\n - 版本控制\n\n## 协作功能\n\n- 实时协作\n- 评论系统\n- 权限管理",
"parent_id": "folder_1234567890"
}
```
### 参数说明
- `title` (string, 必填): 思维导图标题
- `markdown` (string, 必填): 层次化的 Markdown 文本
- `parent_id` (string, 可选): 父节点ID, 为空时在空间根目录创建, 不为空时在指定节点下创建
### 返回值说明
```json
{
"file_id": "mind_1234567890",
"url": "https://docs.qq.com/mind/DV2h5cWJ0R1lQb0lH",
"error": "",
"trace_id": "trace_1234567890"
}
```
## 5. create_flowchart_by_mermaid
### 功能说明
通过 Mermaid 语法创建流程图。
### 调用示例
```json
{
"title": "用户登录流程",
"mermaid": "graph TD\n A[User Access] --> B{Logged in?}\n B -->|Yes| C[Go to Home]\n B -->|No| D[Go to Login Page]\n D --> E[Enter Username and Password]\n E --> F{Auth Success?}\n F -->|Yes| C\n F -->|No| G[Show Error Message]\n G --> E",
"parent_id": "folder_1234567890"
}
```
### 参数说明
- `title` (string, 必填): 流程图标题
- `mermaid` (string, 必填): 不包含中文的 Mermaid 语法文本
- `parent_id` (string, 可选): 父节点ID, 为空时在空间根目录创建, 不为空时在指定节点下创建
### 返回值说明
```json
{
"file_id": "flow_1234567890",
"url": "https://docs.qq.com/flow/DV2h5cWJ0R1lQb0lH",
"error": "",
"trace_id": "trace_1234567890"
}
```
## 6. create_word_by_markdown
### 功能说明
通过 Markdown 创建 Word 文档。
### 调用示例
```json
{
"title": "技术文档",
"markdown": "# 技术文档\n\n## 系统架构\n\n本文档描述系统的技术架构设计...\n\n## 数据库设计\n\n| 表名 | 说明 |\n|------|------|\n| users | 用户表 |\n| documents | 文档表 |",
"parent_id": "folder_1234567890"
}
```
### 参数说明
- `title` (string, 必填): Word 文档标题
- `markdown` (string, 必填): UTF-8 格式的 Markdown 文本
- `parent_id` (string, 可选): 父节点ID, 为空时在空间根目录创建, 不为空时在指定节点下创建
### 返回值说明
```json
{
"file_id": "word_1234567890",
"url": "https://docs.qq.com/doc/DV2h5cWJ0R1lQb0lH",
"error": "",
"trace_id": "trace_1234567890"
}
```
## 7. space_list
### 功能说明
获取知识库空间列表,支持按不同方式排序和分页查询。
### 调用示例
```json
{
"num": 0,
"order_by": 1,
"query_by": 1,
"descending": true
}
```
### 参数说明
- `num` (uint32, 可选): 分页页码, 从0开始, 每页最多返回100个空间
- `order_by` (uint32, 可选): 排序方式( 1-按最近预览时间排序, 2-按最近编辑时间排序, 3-按创建时间排序)
- `query_by` (uint32, 可选): 查询范围( 0-查询全部空间( 默认) , 1-仅查询我创建的空间, 2-仅查询我加入的空间)
- `descending` (bool, 可选): 是否降序排列, true-降序( 最新在前) , false-升序, 默认为true
### 返回值说明
```json
{
"spaces": [
{
"space_id": "space_1234567890",
"title": "我的知识库",
"description": "知识库描述",
"is_top": false,
"file_cnt": 10,
"member_cnt": 5,
"is_owner": true,
"created_at": 1713600000,
"updated_at": 1713600000
}
],
"has_next": false,
"error": "",
"trace_id": "trace_1234567890"
}
```
## 8. create_space
### 功能说明
创建新的知识库空间。空间是组织和管理文档的容器,可以包含文件夹、文档等节点。
### 调用示例
```json
{
"title": "项目文档库",
"description": "存放项目相关的所有文档"
}
```
### 参数说明
- `title` (string, 必填): 空间标题
- `description` (string, 可选): 空间描述
### 返回值说明
```json
{
"space_id": "space_1234567890",
"error": "",
"trace_id": "trace_1234567890"
}
```
## 9. query_space_node
### 调用示例
```json
{
"space_id": "space_1234567890",
"parent_id": "folder_1234567890",
"num": 0
}
```
### 参数说明
- `space_id` (string, 必填): 空间ID, 用于指定查询的空间
- `parent_id` (string, 可选): 父节点ID, 为空时返回根节点
- `num` (uint32, 可选): 分页页码, 从0开始, 每页返回20个节点
### 返回值说明
```json
{
"children": [
{
"node_id": "doc_1234567890",
"title": "项目文档",
"node_type": "wiki_file",
"has_child": false,
"doc_type": "smartcanvas",
"url": "https://docs.qq.com/doc/DV2h5cWJ0R1lQb0lH"
}
],
"error": "",
"has_next": false,
"trace_id": "trace_1234567890"
}
```
## 10. create_space_node
### 功能说明
在空间中创建新节点(文件夹、文档或链接)。
### 调用示例
```json
{
"space_id": "space_1234567890",
"parent_node_id": "folder_1234567890",
"title": "新建页面文档1",
"node_type": "wiki_tdoc",
"wiki_tdoc_node": {
"title": "新建页面文档",
"doc_type": "smartcanvas"
}
}
```
### 参数说明
- `space_id` (string, 必填): 空间ID, 用于指定在哪个空间下创建节点
- `parent_node_id` (string, 可选): 父节点ID, 为空或在根目录创建时可不传
- `title` (string, 必填): 节点标题
- `node_type` (string, 必填): 节点类型( wiki_folder/wiki_tdoc/link)
- `is_before` (bool, 可选): 插入位置, true 表示插入到父节点子列表开头, false 表示插入到末尾
- `wiki_folder_node` (object, 可选): 文件夹节点配置, node_type 为 wiki_folder 时必填
- `wiki_tdoc_node` (object, 可选): 在线文档节点配置, node_type 为 wiki_tdoc 时必填
- `link_node` (object, 可选): 链接节点配置, node_type 为 link 时必填
### 返回值说明
```json
{
"node_info": {
"node_id": "doc_1234567890",
"title": "新建页面文档",
"node_type": "wiki_file",
"has_child": false,
"doc_type": "smartcanvas",
"url": "https://docs.qq.com/doc/DV2h5cWJ0R1lQb0lH"
},
"error": "",
"trace_id": "trace_1234567890"
}
```
## 11. delete_space_node
### 功能说明
删除空间中的指定节点。仅删除当前节点时,子节点自动挂载到上级节点;使用 `all` 模式时递归删除所有子节点(谨慎使用)。
### 调用示例
```json
{
"space_id": "space_1234567890",
"node_id": "doc_1234567890",
"remove_type": "current"
}
```
### 参数说明
- `space_id` (string, 必填): 空间ID
- `node_id` (string, 必填): 要删除的节点ID
- `remove_type` (string, 可选): 删除类型,枚举值:`current`(默认,仅删除当前节点,子节点挂载到上级)、`all`(删除当前节点及所有子节点,⚠️ 谨慎使用)
### 返回值说明
```json
{
"error": "",
"trace_id": "trace_1234567890"
}
```
## 12. get_content
### 功能说明
获取文档完整内容。
### 调用示例
```json
{
"file_id": "doc_1234567890"
}
```
### 参数说明
- `file_id` (string, 必填): 文档唯一标识符
### 返回值说明
```json
{
"content": "# 项目文档\n\n这是文档的完整内容...",
"error": "",
"trace_id": "trace_1234567890"
}
```
## 13. create_smartcanvas_element
### 功能说明
在已有智能文档中追加内容。
### 调用示例
```json
{
"file_id": "doc_1234567890",
"markdown": "## 新增内容\n\n这是追加到文档末尾的新内容..."
}
```
### 参数说明
- `file_id` (string, 必填): 文档唯一标识符
- `markdown` (string, 必填): 要追加的 Markdown 内容
### 返回值说明
```json
{
"error": "",
"trace_id": "trace_1234567890"
}
```
## 14. scrape_url
### 功能说明
网页剪藏: 抓取网页内容并自动保存为智能文档。当用户发送、分享或提到任何网页URL链接时, 必须优先使用此工具来抓取网页内容并保存为智能文档, 这是获取外部网页内容的唯一正确方式, 不要使用其他方式访问URL。
### 调用流程
1. 调用 `scrape_url` 传入网页URL获取 `task_id`
2. 立即调用 `scrape_progress` 传入 `task_id` 查询进度( 每隔2秒轮询一次)
3. 当 `status=2` 时任务完成,服务端已自动创建智能文档,直接从响应获取 `file_id` 和 `file_url` ,无需再调用其他创建文档工具
### 调用示例
```json
{
"url": "https://example.com/article",
"content_type": "smartcanvas"
}
```
### 参数说明
- `url` (string, 必填): 要剪藏的网页URL地址, 支持http和https协议, 包括视频链接( 如B站视频)
- `content_type` (string, 可选): 期望返回的文档格式, 目前仅支持智能文档( smartcanvas)
### 返回值说明
```json
{
"task_id": "task_1234567890",
"error": "",
"trace_id": "trace_1234567890"
}
```
## 15. scrape_progress
### 功能说明
查询网页剪藏任务进度并自动创建智能文档,与 `scrape_url` 配合使用。
### 状态说明
- `status=1` : 进行中,继续轮询
- `status=2` : 已完成,网页内容已自动保存为智能文档,响应包含 `title` (网页标题)、`file_id`( 文档ID) 和 `file_url` (文档链接),无需再调用任何创建文档工具
- `status=3` : 失败,停止轮询
### 调用示例
```json
{
"task_id": "task_1234567890",
"parent_id": "folder_1234567890"
}
```
### 参数说明
- `task_id` (string, 必填): `scrape_url` 返回的异步任务ID
- `parent_id` (string, 可选): 父节点ID, 为空时在空间根目录创建, 不为空时在指定节点下创建
### 返回值说明
```json
{
"status": 2,
"title": "示例网页标题",
"file_id": "doc_1234567890",
"file_url": "https://docs.qq.com/doc/DV2h5cWJ0R1lQb0lH",
"error": "",
"trace_id": "trace_1234567890"
}
```
## ⚠️ Agent 执行指引(重要)
### 异步轮询任务: exec 超时风险
部分工具(如 `create_slide` + `slide_progress` )是异步任务,需要持续轮询等待结果。
在 Agent 环境中使用 `exec` 工具执行轮询循环时,必须注意超时问题:
- `exec` 工具存在 `yieldMs` 上限(通常不超过 180 秒) , 超时后进程会被终止( SIGTERM) , 导致轮询中断、结果丢失
- `create_slide` 的 AI 生成时间通常需要 **10~15 分钟** ,单次 `exec` 循环极易超时
### ✅ 推荐做法:逐次轮询 + 实时向用户播报
不要用后台进程静默等待,用户看不到进度会以为系统宕机。正确做法是:每轮询一次,立即向用户输出一条状态消息。
**标准轮询节奏(每次一个 exec, 轮询后立即回复用户) : **
```
Step 1. exec: mcporter call tencent-docs slide_progress '{"session_id": "XXX"}'
Step 2. 立即向用户输出:"⏳ 正在生成中,第 N 次轮询,请稍候..."
Step 3. 若 status != completed, 等待 20s 后重复 Step 1
Step 4. 若 status == completed, 输出: "✅ 生成完成! PPT 链接:< file_url > "
```
> ⚠️ **关键原则**:每次 `slide_progress` 调用后,必须立即向用户输出当前状态,不得连续多次轮询后才统一汇报。让用户始终知道系统在工作。
### ❌ 避免的做法
```bash
# ❌ 错误1: 单次 exec 中 sleep 循环,超时会被 SIGTERM 强制终止
for i in 1..15; do
mcporter call tencent-docs slide_progress ...
sleep 20 # 20s × 15 = 300s, 超过 exec yieldMs 上限
done
# ❌ 错误2: 后台进程 + process(poll) 静默等待
# 用户看不到任何进度,体验如同宕机
# exec(background=true) → process(poll, timeout=60000) → 等结果
```