lark-slides

飞书幻灯片:以 XML 格式读取和管理 PPT 页面。创建演示文稿优先用 `+create`;XML API 主要用于读取 PPT 全文信息、创建和删除幻灯片页面。当用户需要创建 PPT、读取 PPT 内容、管理幻灯片页面时使用。

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "lark-slides" with this command: npx skills add larksuite/cli/larksuite-cli-lark-slides

slides (v1)

CRITICAL — 开始前 MUST 先用 Read 工具读取 ../lark-shared/SKILL.md,其中包含认证、权限处理

CRITICAL — 生成任何 XML 之前,MUST 先用 Read 工具读取 xml-schema-quick-ref.md,禁止凭记忆猜测 XML 结构。

身份选择

飞书幻灯片通常是用户自己的内容资源。默认应优先显式使用 --as user(用户身份)执行 slides 相关操作,始终显式指定身份。

  • --as user(推荐):以当前登录用户身份创建、读取、管理演示文稿。执行前先完成用户授权:
lark-cli auth login --domain slides
  • --as bot:仅在用户明确要求以应用身份操作,或需要让 bot 持有/创建资源时使用。使用 bot 身份时,要额外确认 bot 是否真的有目标演示文稿的访问权限。

执行规则

  1. 创建、读取、增删 slide、按用户给出的链接继续编辑已有 PPT,默认都先用 --as user
  2. 如果出现权限不足,先检查当前是否误用了 bot 身份;不要默认回退到 bot。
  3. 只有在用户明确要求“用应用身份 / bot 身份操作”,或当前工作流就是 bot 创建资源后再做协作授权时,才切换到 --as bot

快速开始

一条命令创建包含页面内容的 PPT(推荐):

lark-cli slides +create --title "演示文稿标题" --slides '[
  "<slide xmlns=\"http://www.larkoffice.com/sml/2.0\"><style><fill><fillColor color=\"rgb(245,245,245)\"/></fill></style><data><shape type=\"text\" topLeftX=\"80\" topLeftY=\"80\" width=\"800\" height=\"100\"><content textType=\"title\"><p>页面标题</p></content></shape><shape type=\"text\" topLeftX=\"80\" topLeftY=\"200\" width=\"800\" height=\"200\"><content textType=\"body\"><p>正文内容</p><ul><li><p>要点一</p></li><li><p>要点二</p></li></ul></content></shape></data></slide>"
]'

也可以分两步(先创建空白 PPT,再逐页添加),详见 +create 参考文档

以上是最小可用示例。更丰富的页面效果(渐变背景、卡片、图表、表格等),参考下方 Workflow 和 XML 模板。

执行前必做

重要references/slides_xml_schema_definition.xml 是此 skill 唯一正确的 XML 协议来源;其他 md 仅是对它和 CLI schema 的摘要。

必读(每次创建前)

文档说明
xml-schema-quick-ref.mdXML 元素和属性速查,必读

选读(需要时查阅)

场景文档
需要了解详细 XML 结构xml-format-guide.md
需要 CLI 调用示例examples.md
需要参考真实 PPT 的 XMLslides_demo.xml
需要用 table/chart 等复杂元素slides_xml_schema_definition.xml(完整 Schema)
需要了解某个命令的详细参数对应命令的 reference 文档(见下方参考文档章节)

Workflow

这是演示文稿,不是文档。 每页 slide 是独立的视觉画面,信息密度要低,排版要留白。

Step 1: 需求澄清 & 读取知识
  - 澄清用户需求:主题、受众、页数、风格偏好
  - 如果用户没有明确风格,根据主题推荐(见下方风格判断表)
  - 读取 XML Schema 参考:
    · xml-schema-quick-ref.md — 元素和属性速查
    · xml-format-guide.md — 详细结构与示例
    · slides_demo.xml — 真实 XML 示例

Step 2: 生成大纲 → 用户确认 → 创建
  - 生成结构化大纲(每页标题 + 要点 + 布局描述),交给用户确认
  - 10 页以内:用 slides +create --slides '[...]' 一步创建 PPT 并添加所有页面
  - 超过 10 页:先 `slides +create` 创建空白 PPT,再用 `xml_presentation.slide.create` 逐页添加
  - 每页 slide 需要完整的 XML:背景、文本、图形、配色
  - 复杂元素(table、chart)需参考 XSD 原文

Step 3: 审查 & 交付
  - 创建完成后,用 xml_presentations.get 读取全文 XML,确认:
    · 页数是否正确?每页内容是否完整?
    · 配色是否统一?字号层级是否合理?
  - 有问题 → 用 xml_presentation.slide.delete 删除问题页,重新创建
  - 没问题 → 交付:告知用户演示文稿 ID 和访问方式

jq 命令模板(编辑已有 PPT 时使用)

新建 PPT 推荐用 +create --slides。以下 jq 模板适用于向已有演示文稿追加页面的场景,可以避免手动转义双引号:

lark-cli slides xml_presentation.slide create \
  --as user \
  --params '{"xml_presentation_id":"YOUR_ID"}' \
  --data "$(jq -n --arg content '<slide xmlns="http://www.larkoffice.com/sml/2.0">
  <style><fill><fillColor color="BACKGROUND_COLOR"/></fill></style>
  <data>
    在这里放置 shape、line、table、chart 等元素
  </data>
</slide>' '{slide:{content:$content}}')"

风格快速判断表

注意:渐变色必须使用 rgba() 格式并带百分比停靠点,如 linear-gradient(135deg,rgba(15,23,42,1) 0%,rgba(56,97,140,1) 100%)。使用 rgb() 或省略停靠点会导致服务端回退为白色。

场景/主题推荐风格背景主色文字色
科技/AI/产品深色科技风深蓝渐变 linear-gradient(135deg,rgba(15,23,42,1) 0%,rgba(56,97,140,1) 100%)蓝色系 rgb(59,130,246)白色
商务汇报/季度总结浅色商务风浅灰 rgb(248,250,252)深蓝 rgb(30,60,114)深灰 rgb(30,41,59)
教育/培训清新明亮风白色 rgb(255,255,255)绿色系 rgb(34,197,94)深灰 rgb(51,65,85)
创意/设计渐变活力风紫粉渐变 linear-gradient(135deg,rgba(88,28,135,1) 0%,rgba(190,24,93,1) 100%)粉紫色系白色
周报/日常汇报简约专业风浅灰 rgb(248,250,252) + 顶部彩色渐变条蓝色 rgb(59,130,246)深色 rgb(15,23,42)
用户未指定默认简约专业风同上同上同上

页面布局建议

页面类型布局要点
封面页居中大标题 + 副标题 + 底部信息,背景用渐变或深色
数据概览页指标卡片横排(rect 背景 + 大号数字 + 小号说明),下方列表或图表
内容页左侧竖线装饰 + 标题,下方分栏或列表
对比/表格页table 元素或并列卡片,表头深色背景白字
图表页chart 元素(column/line/pie),配合文字说明
结尾页居中感谢语 + 装饰线,风格与封面呼应

大纲模板

生成大纲时使用以下格式,交给用户确认:

[PPT 标题] — [定位描述],面向 [目标受众]

页面结构(N 页):
1. 封面页:[标题文案]
2. [页面主题]:[要点1]、[要点2]、[要点3]
3. [页面主题]:[要点描述]
...
N. 结尾页:[结尾文案]

风格:[配色方案],[排版风格]

常用 Slide XML 模板

可直接复制使用的模板(封面页、内容页、数据卡片页、结尾页):slide-templates.md


核心概念

URL 格式与 Token

URL 格式示例Token 类型处理方式
/slides/https://example.larkoffice.com/slides/xxxxxxxxxxxxxxml_presentation_idURL 路径中的 token 直接作为 xml_presentation_id 使用
/wiki/https://example.larkoffice.com/wiki/wikcnxxxxxxxxxwiki_token⚠️ 不能直接使用,需要先查询获取真实的 obj_token

Wiki 链接特殊处理(关键!)

知识库链接(/wiki/TOKEN)背后可能是云文档、电子表格、幻灯片等不同类型的文档。不能直接假设 URL 中的 token 就是 xml_presentation_id,必须先查询实际类型和真实 token。

处理流程

  1. 使用 wiki.spaces.get_node 查询节点信息

    lark-cli wiki spaces get_node --as user --params '{"token":"wiki_token"}'
    
  2. 从返回结果中提取关键信息

    • node.obj_type:文档类型,幻灯片对应 slides
    • node.obj_token真实的演示文稿 token(用于后续操作)
    • node.title:文档标题
  3. 确认 obj_typeslides 后,使用 obj_token 作为 xml_presentation_id

查询示例

# 查询 wiki 节点
lark-cli wiki spaces get_node --as user --params '{"token":"wikcnxxxxxxxxx"}'

返回结果示例:

{
   "node": {
      "obj_type": "slides",
      "obj_token": "xxxxxxxxxxxx",
      "title": "2026 产品年度总结",
      "node_type": "origin",
      "space_id": "1234567890"
   }
}
# 用 obj_token 读取幻灯片内容
lark-cli slides xml_presentations get --as user --params '{"xml_presentation_id":"xxxxxxxxxxxx"}'

资源关系

Wiki Space (知识空间)
└── Wiki Node (知识库节点, obj_type: slides)
    └── obj_token → xml_presentation_id

Slides (演示文稿)
├── xml_presentation_id (演示文稿唯一标识)
├── revision_id (版本号)
└── Slide (幻灯片页面)
    └── slide_id (页面唯一标识)

Shortcuts(推荐优先使用)

Shortcut 是对常用操作的高级封装(lark-cli slides +<verb> [flags])。有 Shortcut 的操作优先使用。

Shortcut说明
+create创建 PPT(可选 --slides 一步添加页面),bot 模式自动授权

API Resources

lark-cli schema slides.<resource>.<method>    # 调用 API 前必须先查看参数结构
lark-cli slides <resource> <method> [flags]  # 调用 API

重要:使用原生 API 时,必须先运行 schema 查看 --data / --params 参数结构,不要猜测字段格式。

xml_presentations

  • get — 读取ppt全文信息,xml格式返回

xml_presentation.slide

  • create — 在指定 xml 演示文稿下创建页面
  • delete — 删除指定 xml 演示文稿下的页面

核心规则

  1. 先出大纲再动手:创建 PPT 前先生成大纲交给用户确认,避免返工
  2. 创建流程:10 页以内推荐 slides +create --slides '[...]' 一步创建;超过 10 页先 slides +create 创建空白 PPT,再用 xml_presentation.slide.create 逐页添加
  3. <slide> 直接子元素只有 <style><data><note>:文本和图形必须放在 <data>
  4. 文本通过 <content> 表达:必须用 <content><p>...</p></content>,不能把文字直接写在 shape 内
  5. 保存关键 ID:后续操作需要 xml_presentation_idslide_idrevision_id
  6. 删除谨慎:删除操作不可逆,且至少保留一页幻灯片

权限表

方法所需 scope
slides +createslides:presentation:create, slides:presentation:write_only
xml_presentations.getslides:presentation:read
xml_presentation.slide.createslides:presentation:updateslides:presentation:write_only
xml_presentation.slide.deleteslides:presentation:updateslides:presentation:write_only

常见错误速查

错误码含义解决方案
400XML 格式错误检查 XML 语法,确保标签闭合
400create 内容超出支持范围xml_presentations.create 仅用于创建空白 PPT,不要在这里传完整 slide 内容
400请求包装错误检查 --data 是否按 schema 传入 xml_presentation.contentslide.content
404演示文稿不存在检查 xml_presentation_id 是否正确
404幻灯片不存在检查 slide_id 是否正确
403权限不足检查是否拥有对应的 scope
400无法删除唯一幻灯片演示文稿至少保留一页幻灯片

创建前自查

逐页生成 XML 前,快速检查:

  • 每页背景色/渐变是否设置?风格是否与整体一致?
  • 标题用大字号(28-48),正文用小字号(13-16),层级分明?
  • 同类元素配色一致?(如所有指标卡片同色系、所有正文同色)
  • 装饰元素(分割线、色块、竖线)颜色是否与主色协调?
  • 文本框尺寸是否足够容纳内容?(宽度 × 高度)
  • shape 的 type 是否正确?(文本框用 text,装饰用 rect
  • XML 标签是否全部正确闭合?特殊字符(&<>)是否转义?

症状 → 修复表

看到的问题改什么
文字被截断/看不全增大 shape 的 widthheight
元素重叠调整 topLeftX/topLeftY,拉开间距
页面大面积空白缩小元素间距,或增加内容填充
文字和背景色太接近深色背景用浅色文字,浅色背景用深色文字
表格列宽不合理调整 colgroupcolwidth
图表没有显示检查 chartPlotAreachartData 是否都包含,dim1/dim2 数据数量是否匹配
渐变背景变成白色渐变必须用 rgba() 格式 + 百分比停靠点,如 linear-gradient(135deg,rgba(30,60,114,1) 0%,rgba(59,130,246,1) 100%);用 rgb() 或省略停靠点会被回退为白色
渐变方向不对调整 linear-gradient 的角度(90deg 水平、180deg 垂直、135deg 对角线)
整体风格不统一封面页和结尾页用同一背景,内容页保持一致的配色和字号体系
API 返回 400检查 XML 语法:标签闭合、属性引号、特殊字符转义
API 返回 3350001xml_presentation_id 不是通过 xml_presentations.create 创建的,或 token 不正确

参考文档

文档说明
lark-slides-create.md+create Shortcut:创建 PPT(支持 --slides 一步添加页面)
xml-schema-quick-ref.mdXML Schema 精简速查(必读)
slide-templates.md可复制的 Slide XML 模板
xml-format-guide.mdXML 详细结构与示例
examples.mdCLI 调用示例
slides_demo.xml真实 PPT 的完整 XML
slides_xml_schema_definition.xml完整 Schema 定义(唯一协议依据)
lark-slides-xml-presentations-create.md创建空白 PPT 命令详情
lark-slides-xml-presentations-get.md读取 PPT 命令详情
lark-slides-xml-presentation-slide-create.md添加幻灯片命令详情
lark-slides-xml-presentation-slide-delete.md删除幻灯片命令详情

注意:如果 md 内容与 slides_xml_schema_definition.xmllark-cli schema slides.<resource>.<method> 输出不一致,以后两者为准。

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

lark-doc

飞书云文档:创建和编辑飞书文档。从 Markdown 创建文档、获取文档内容、更新文档(追加/覆盖/替换/插入/删除)、上传和下载文档中的图片和文件、搜索云空间文档。当用户需要创建或编辑飞书文档、读取文档内容、在文档中插入图片、搜索云空间文档时使用;如果用户是想按名称或关键词先定位电子表格、报表等云空间对象,也优先使用本 skill 的 docs +search 做资源发现。

Repository Source
52.3K7.5Klarksuite
Coding

lark-base

当需要用 lark-cli 操作飞书多维表格(Base)时调用:适用于建表、字段管理、记录读写、视图配置、历史查询,以及角色/表单/仪表盘管理/工作流;也适用于把旧的 +table / +field / +record 写法改成当前命令写法。涉及字段设计、公式字段、查找引用、跨表计算、行级派生指标、数据分析需求时也必须使用本 skill。

Repository Source
52.2K7.5Klarksuite
Coding

lark-im

飞书即时通讯:收发消息和管理群聊。发送和回复消息、搜索聊天记录、管理群聊成员、上传下载图片和文件(支持大文件分片下载)、管理表情回复。当用户需要发消息、查看或搜索聊天记录、下载聊天中的文件、查看群成员时使用。

Repository Source
52.2K7.5Klarksuite
Coding

lark-calendar

飞书日历(calendar):提供日历与日程(会议)的全面管理能力。核心场景包括:查看/搜索日程、创建/更新日程、管理参会人、查询忙闲状态及推荐空闲时段、查询/搜索与预定会议室。注意:涉及【预约日程/会议】或【查询/预定会议室】时,必须先读取 references/lark-calendar-schedule-meeting.md 工作流!高频操作请优先使用 Shortcuts:+agenda(快速概览今日/近期行程)、+create(创建日程并按需邀请参会人及预定会议室)、+freebusy(查询用户主日历的忙闲信息和rsvp的状态)、+rsvp(回复日程邀请)

Repository Source
52.1K7.5Klarksuite