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
'[
" 页面标题 正文内容 要点一 要点二slides +create 创建空白 PPT,再用 xml_presentation.slide.create 逐页添加
- 含本地图片:
· 新建带图 PPT —— 在 slide XML 里写
,
+create 会自动上传并替换为 file_token(详见 lark-slides-create.md)
· 给已有 PPT 加带图新页 —— 先 slides +media-upload --file ./pic.png --presentation $PID
拿到 file_token,再用它写进 slide XML 调 xml_presentation.slide.create
· 给已有页加图 —— XML API 无元素级编辑,需要整页替换;必守规则和流程见下方「给已有 PPT 的已有页加图」章节
· 路径必须是 CWD 内的相对路径(如 ./pic.png 或 ./assets/x.png);
绝对路径会被 CLI 拒绝,先 cd 到素材所在目录再执行
- 每页 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
'
在这里放置 shape、line、table、chart 等元素 ' '{slide:{content:$content}}' ) "
插到指定页之前:before_slide_id 必须在 --data body 里,与 slide 同级
⚠️ 不要把 before_slide_id 写进 --params —— CLI 会当未知 query 参数静默下发,服务端忽略,新页跑到末尾
lark-cli slides xml_presentation.slide create
\
--as
user
\
--params
'{"xml_presentation_id":"YOUR_ID"}'
\
--data
"
$(
jq
-n
--arg
content
'
→ 原位 create 新页 → 删除旧页。
必守 4 条
:
先 create 后 delete
—— 顺序反了且 create 失败会丢页
原 slide 的所有元素必须原样搬到新 XML
(标题、正文、形状、原有 img)—— 只写新
会把原页其他内容全删掉
before_slide_id=<旧 slide_id>
必传,且必须放在
--data
body 里
(与
slide
同级),
不能放在
--params
——
--params
只接 path/query 参数,body 字段塞进去会被 CLI 当未知 query 参数静默下发,服务端忽略,结果是新页追加到末尾、打乱页序。正确形状:
--data '{"slide":{"content":"..."},"before_slide_id":"<旧 slide_id>"}'
新
坐标避开现有元素
—— 读原
里元素的
topLeftX/Y/width/height
挑空白区;空间不够就先缩小/挪动现有元素再放图
完整 bash 模板和
+media-upload
参数见
+media-upload 文档
。
风格快速判断表
注意
:渐变色必须使用
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 +
占位符自动上传),bot 模式自动授权
+media-upload
上传本地图片到指定演示文稿,返回
file_token
(用作
),最大 20 MB
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
逐页添加
...