lark-slides
Generates Lark slides, adhering to XML Schema specifications, supporting authentication and permission management.
npx skills add larksuite/cli --skill lark-slidesBefore / After Comparison
1 组Manually creating slides, designing layouts, selecting templates, adjusting formats and typesetting, a 20-page presentation takes 3-4 hours.
Automatically generate standard-compliant slide XML, automatically apply layouts and formats, quickly complete presentation creation.
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 是否真的有目标演示文稿的访问权限。
执行规则:
-
创建、读取、增删 slide、按用户给出的链接继续编辑已有 PPT,默认都先用
--as user。 -
如果出现权限不足,先检查当前是否误用了 bot 身份;不要默认回退到 bot。
-
只有在用户明确要求“用应用身份 / 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.md XML 元素和属性速查,必读
选读(需要时查阅)
场景 文档
需要了解详细 XML 结构 xml-format-guide.md
需要 CLI 调用示例 examples.md
需要参考真实 PPT 的 XML slides_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/xxxxxxxxxxxxx
xml_presentation_id
URL 路径中的 token 直接作为 xml_presentation_id 使用
/wiki/
https://example.larkoffice.com/wiki/wikcnxxxxxxxxx
wiki_token
⚠️ 不能直接使用,需要先查询获取真实的 obj_token
Wiki 链接特殊处理(关键!)
知识库链接(/wiki/TOKEN)背后可能是云文档、电子表格、幻灯片等不同类型的文档。不能直接假设 URL 中的 token 就是 xml_presentation_id,必须先查询实际类型和真实 token。
处理流程
使用 wiki.spaces.get_node 查询节点信息
lark-cli wiki spaces get_node --as user --params '{"token":"wiki_token"}'
从返回结果中提取关键信息
node.obj_type:文档类型,幻灯片对应 slides
-
node.obj_token:真实的演示文稿 token(用于后续操作) -
node.title:文档标题
确认 obj_type 为 slides 后,使用 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 演示文稿下的页面
核心规则
-
先出大纲再动手:创建 PPT 前先生成大纲交给用户确认,避免返工
-
创建流程:10 页以内推荐
slides +create --slides '[...]'一步创建;超过 10 页先slides +create创建空白 PPT,再用xml_presentation.slide.create逐页添加 -
<slide>直接子元素只有<style>、<data>、<note>:文本和图形必须放在<data>内 -
文本通过
<content>表达:必须用<content><p>...</p></content>,不能把文字直接写在 shape 内 -
保存关键 ID:后续操作需要
xml_presentation_id、slide_id、revision_id -
删除谨慎:删除操作不可逆,且至少保留一页幻灯片
权限表
方法 所需 scope
slides +create
slides:presentation:create, slides:presentation:write_only
xml_presentations.get
slides:presentation:read
xml_presentation.slide.create
slides:presentation:update 或 slides:presentation:write_only
xml_presentation.slide.delete
slides:presentation:update 或 slides:presentation:write_only
常见错误速查
错误码 含义 解决方案
400 XML 格式错误 检查 XML 语法,确保标签闭合
400
create 内容超出支持范围
xml_presentations.create 仅用于创建空白 PPT,不要在这里传完整 slide 内容
400
请求包装错误
检查 --data 是否按 schema 传入 xml_presentation.content 或 slide.content
404
演示文稿不存在
检查 xml_presentation_id 是否正确
404
幻灯片不存在
检查 slide_id 是否正确
403 权限不足 检查是否拥有对应的 scope
400 无法删除唯一幻灯片 演示文稿至少保留一页幻灯片
创建前自查
逐页生成 XML 前,快速检查:
-
每页背景色/渐变是否设置?风格是否与整体一致?
-
标题用大字号(28-48),正文用小字号(13-16),层级分明?
-
同类元素配色一致?(如所有指标卡片同色系、所有正文同色)
-
装饰元素(分割线、色块、竖线)颜色是否与主色协调?
-
文本框尺寸是否足够容纳内容?(宽度 × 高度)
-
shape 的
type是否正确?(文本框用text,装饰用rect) -
XML 标签是否全部正确闭合?特殊字符(
&、<、>)是否转义?
症状 → 修复表
看到的问题 改什么
文字被截断/看不全
增大 shape 的 width 或 height
元素重叠
调整 topLeftX/topLeftY,拉开间距
页面大面积空白 缩小元素间距,或增加内容填充
文字和背景色太接近 深色背景用浅色文字,浅色背景用深色文字
表格列宽不合理
调整 colgroup 中 col 的 width 值
图表没有显示
检查 chartPlotArea 和 chartData 是否都包含,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 返回 3350001
xml_presentation_id 不是通过 xml_presentations.create 创建的,或 token 不正确
参考文档
文档 说明
lark-slides-create.md
+create Shortcut:创建 PPT(支持 --slides 一步添加页面)
xml-schema-quick-ref.md XML Schema 精简速查(必读)
slide-templates.md 可复制的 Slide XML 模板
xml-format-guide.md XML 详细结构与示例
examples.md CLI 调用示例
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.xml 或 lark-cli schema slides.<resource>.<method> 输出不一致,以后两者为准。
Weekly Installs5.5KRepositorylarksuite/cliGitHub Stars7.5KFirst Seen3 days agoSecurity AuditsGen Agent Trust HubPassSocketPassSnykFailInstalled oncodex5.5Kcursor5.5Kopencode5.5Kgemini-cli5.5Kgithub-copilot5.5Kkimi-cli5.5K
User Reviews (0)
Write a Review
No reviews yet
Statistics
User Rating
Rate this Skill