jpskill.com
🛠️ 開発・MCP コミュニティ

lark-slides

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

⚡ おすすめ: コマンド1行でインストール(60秒)

下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。

🍎 Mac / 🐧 Linux
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o lark-slides.zip https://jpskill.com/download/19590.zip && unzip -o lark-slides.zip && rm lark-slides.zip
🪟 Windows (PowerShell)
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/19590.zip -OutFile "$d\lark-slides.zip"; Expand-Archive "$d\lark-slides.zip" -DestinationPath $d -Force; ri "$d\lark-slides.zip"

完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。

💾 手動でダウンロードしたい(コマンドが難しい人向け)
  1. 1. 下の青いボタンを押して lark-slides.zip をダウンロード
  2. 2. ZIPファイルをダブルクリックで解凍 → lark-slides フォルダができる
  3. 3. そのフォルダを C:\Users\あなたの名前\.claude\skills\(Win)または ~/.claude/skills/(Mac)へ移動
  4. 4. Claude Code を再起動

⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。

🎯 このSkillでできること

下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。

📦 インストール方法 (3ステップ)

  1. 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
  2. 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
  3. 3. 展開してできたフォルダを、ホームフォルダの .claude/skills/ に置く
    • · macOS / Linux: ~/.claude/skills/
    • · Windows: %USERPROFILE%\.claude\skills\

Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。

詳しい使い方ガイドを見る →
最終更新
2026-05-18
取得日時
2026-05-18
同梱ファイル
12

📖 Skill本文(日本語訳)

※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。

[Skill 名] lark-slides

slides (v1)

重要 — 開始する前に、必ず Read ツールで ../lark-shared/SKILL.md を読み込んでください。これには認証と権限処理が含まれています。

重要 — XML を生成する前に、必ず Read ツールで xml-schema-quick-ref.md を読み込んでください。XML 構造を記憶に頼って推測することは禁止されています。

認証情報の選択

飛書スライドは通常、ユーザー自身のコンテンツリソースです。デフォルトでは、--as user(ユーザー認証情報)を明示的に使用してスライド関連の操作を実行することを優先し、常に認証情報を明示的に指定する必要があります。

  • --as user(推奨):現在ログインしているユーザーとしてプレゼンテーションを作成、読み取り、管理します。実行前にユーザー認証を完了してください。
lark-cli auth login --domain slides
  • --as bot:ユーザーが明示的にアプリケーションとして操作を要求した場合、または bot がリソースを所有/作成する必要がある場合にのみ使用します。bot 認証情報を使用する場合は、bot が対象のプレゼンテーションへのアクセス権を持っていることを追加で確認する必要があります。

実行ルール

  1. 作成、読み取り、スライドの追加/削除、ユーザーが提供したリンクによる既存の PPT の編集は、デフォルトで --as user を使用します。
  2. 権限不足が発生した場合は、まず現在 bot 認証情報を誤って使用していないか確認してください。デフォルトで bot にフォールバックしないでください。
  3. ユーザーが明示的に「アプリケーション認証情報 / bot 認証情報で操作する」と要求した場合、または現在のワークフローが bot がリソースを作成した後に共同作業の承認を行うものである場合にのみ、--as bot に切り替えます。

クイックスタート

1 つのコマンドでページコンテンツを含む 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>要点1</p></li><li><p>要点2</p></li></ul></content></shape></data></slide>"
]'

2 段階で実行することもできます(まず空白の PPT を作成し、次にページを 1 つずつ追加します)。詳細については、+create リファレンスドキュメント を参照してください。

上記は最小限の利用可能な例です。より豊富なページ効果(グラデーション背景、カード、グラフ、表など)については、以下の Workflow と XML テンプレートを参照してください。

実行前の必須事項

重要references/slides_xml_schema_definition.xml は、このスキルにとって唯一正しい XML プロトコルのソースです。他の md は、それと CLI スキーマの要約にすぎません。

必須(作成ごとに)

ドキュメント 説明
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(完全なスキーマ)
特定のコマンドの詳細なパラメータを知る必要がある場合 対応するコマンドのリファレンスドキュメント(以下のリファレンスドキュメントセクションを参照)

Workflow

これはプレゼンテーションであり、ドキュメントではありません。 各スライドは独立した視覚的な画面であり、情報密度は低く、レイアウトには余白が必要です。

Step 1: 要件の明確化と知識の読み込み
  - ユーザー要件の明確化:テーマ、対象者、ページ数、スタイルの好み
  - ユーザーが明確なスタイルを指定しない場合、テーマに基づいて推奨(以下のスタイル判断表を参照)
  - XML スキーマの参照を読み込む:
    ・ 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` でページを 1 つずつ追加する
  - ローカル画像を含む場合:
    ・ 画像付きの新しい PPT を作成する — スライド XML に <img src="@./pic.png" .../> を記述すると、
      +create が自動的にアップロードし、file_token に置き換えます(詳細は lark-slides-create.md を参照)
    ・ 既存の PPT に画像付きの新しいページを追加する — まず `slides +media-upload --file ./pic.png --presentation $PID`
      で file_token を取得し、それを使用してスライド XML に記述し、xml_presentation.slide.create を呼び出す
    ・ 既存のページに画像を追加する — XML API には要素レベルの編集機能がないため、ページ全体を置き換える必要があります。必須のルールとプロセスは以下の「既存の PPT の既存のページに画像を追加する」セクションを参照してください。
    ・ パスは CWD 内の相対パスである必要があります(例:./pic.png または ./assets/x.png)。
      絶対パスは CLI によって拒否されるため、素材のあるディレクトリに cd してから実行してください。
  - 各スライドには完全な 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}}')"

# 指定したページの前に追加:before_slide_id は --data body 内に、slide と同じ階層に記述する必要があります
# ⚠️ before_slide_id を --params に記述しないでください — CLI は不明なクエリパラメータとしてサイレントに送信し、サーバーは無視するため、新しいページは末尾に追加されます
lark-cli slides xml_presentation.slide create \
  --as user \
  --params '{"xml_presentation_id":"YOUR_ID"}' \
  --data "$(jq -n --arg content '<slide ...>...</slide>' --arg before 'TARGET_SLIDE_ID' \
    '{slide:{content:$content}, before_slide_id:$before}')"

既存の PPT の既存のページに画像を追加する(ページ全体を置き換え)

XML API には要素レベルの編集インターフェースがありません(コアルール 7 を参照)。特定のページに画像を追加したい場合は、ページ全体を置き換えるしかありません。元のスライドを読み込み → <img> を追加 → 元の位置に新しいページを作成 → 古いページを削除、という手順になります。

必須の 4 つのルール

  1. create を先に、delete を後に — 順序が逆で create が失敗するとページが失われます。
  2. 元のスライドのすべての要素は、新しい XML にそのまま移行する必要があります(タイトル、本文、図形、既存の img)— 新しい <img> だけを記述すると、元のページの他の内容がすべて削除されます。
  3. before_slide_id=<旧 slide_id> は必須で、--data body 内に記述する必要がありますslide と同じ階層)。--params に記述してはいけません--params は path/query パラメータのみを受け入れます。body フィールドをそこに挿入すると、CLI は不明なクエリパラメータとしてサイレントに送信し、サーバーは無視するため、結果として新しいページが末尾に追加され、ページ順序が乱れます。正しい形式:--data '{"slide":{"content":"..."},"before_slide_id":"<旧 slide_id>"}'
  4. 新しい <img> の座標は既存の要素を避けてください — 元の <data> 内の要素の 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. [ページ

(原文がここで切り詰められています)
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開

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.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` 逐页添加
  - 含本地图片:
    · 新建带图 PPT —— 在 slide XML 里写 <img src="@./pic.png" .../>,
      +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 '<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}}')"

# 插到指定页之前: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 '<slide ...>...</slide>' --arg before 'TARGET_SLIDE_ID' \
    '{slide:{content:$content}, before_slide_id:$before}')"

给已有 PPT 的已有页加图(整页替换)

XML API 没有元素级编辑接口(见核心规则 7)。想给某一页加图,只能整页替换:读原 slide → 加 <img> → 原位 create 新页 → 删除旧页。

必守 4 条

  1. 先 create 后 delete —— 顺序反了且 create 失败会丢页
  2. 原 slide 的所有元素必须原样搬到新 XML(标题、正文、形状、原有 img)—— 只写新 <img> 会把原页其他内容全删掉
  3. before_slide_id=<旧 slide_id> 必传,且必须放在 --data body 里(与 slide 同级),不能放在 --params —— --params 只接 path/query 参数,body 字段塞进去会被 CLI 当未知 query 参数静默下发,服务端忽略,结果是新页追加到末尾、打乱页序。正确形状:--data '{"slide":{"content":"..."},"before_slide_id":"<旧 slide_id>"}'
  4. <img> 坐标避开现有元素 —— 读原 <data> 里元素的 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。

处理流程

  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 一步添加页面,支持 <img src="@./local.png"> 占位符自动上传),bot 模式自动授权
+media-upload 上传本地图片到指定演示文稿,返回 file_token(用作 <img src="...">),最大 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 演示文稿下的页面

核心规则

  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. 删除谨慎:删除操作不可逆,且至少保留一页幻灯片
  7. 没有元素级编辑能力:飞书 slides XML API 只有 slide 级 create / delete没有更新单个 shape/img 坐标或尺寸的接口。不要向用户承诺"微调坐标/尺寸"、"挪一下这个图"。要改只能整页重建(xml_presentations.get 读回 → 改 XML → slide.delete 旧页 + slide.create 新页),且 slide_id 会变、默认追加到末尾(要回原位需 before_slide_id)。整页重建前必须先告知用户代价并确认
  8. <img src> 只能用上传到飞书 drive 的 file_token,禁止使用 http(s) 外链 URL:飞书 slides 渲染端不会代理外链图片,外链 src 在 PPT 里通常不显示或显示破图。流程必须是「先把图存到本地 → 用 slides +media-upload 上传或 +create --slides@./path 占位符自动上传 → 拿 file_token 写进 <img src>」。如果用户给了网图链接,先 curl/下载到 CWD 内再走上传流程,不要直接把外链 URL 塞进 src图片最大 20 MB(slides upload API 不支持分片上传)。

权限表

方法 所需 scope
slides +create slides:presentation:create, slides:presentation:write_only(含 @ 占位符时还需 docs:document.media:upload
slides +media-upload docs:document.media:upload(wiki URL 解析还需 wiki:node:read
xml_presentations.get slides:presentation:read
xml_presentation.slide.create slides:presentation:updateslides:presentation:write_only
xml_presentation.slide.delete slides:presentation:updateslides:presentation:write_only

常见错误速查

错误码 含义 解决方案
400 XML 格式错误 检查 XML 语法,确保标签闭合
400 create 内容超出支持范围 xml_presentations.create 仅用于创建空白 PPT,不要在这里传完整 slide 内容
400 请求包装错误 检查 --data 是否按 schema 传入 xml_presentation.contentslide.content
404 演示文稿不存在 检查 xml_presentation_id 是否正确
404 幻灯片不存在 检查 slide_id 是否正确
403 权限不足 检查是否拥有对应的 scope
400 无法删除唯一幻灯片 演示文稿至少保留一页幻灯片
1061002 params error(媒体上传时) slides +media-upload,不要手拼原生 medias/upload_all;slides 唯一可用 parent_typeslide_file
1061004 forbidden:当前身份对演示文稿无编辑权限 确认 user/bot 对目标 PPT 有编辑权限;bot 常见于 PPT 非该 bot 创建,需先授权或用 +create --as bot 新建
validation: unsafe file path --file 给了绝对路径或上层路径 --file 必须是 CWD 内相对路径;先 cd 到素材目录再执行

创建前自查

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

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

症状 → 修复表

看到的问题 改什么
文字被截断/看不全 增大 shape 的 widthheight
元素重叠 调整 topLeftX/topLeftY,拉开间距
页面大面积空白 缩小元素间距,或增加内容填充
文字和背景色太接近 深色背景用浅色文字,浅色背景用深色文字
表格列宽不合理 调整 colgroupcolwidth
图表没有显示 检查 chartPlotAreachartData 是否都包含,dim1/dim2 数据数量是否匹配
图片被裁掉一部分 <img>width/height 是裁剪后尺寸,比例和原图不一致时会自动裁剪;要整图显示就让 width:height 对齐原图比例
给已有页加图后,原页文字/形状消失了 替换整页时必须把原 slide 的 <data> 所有元素原样搬过来,不能只写新 <img>
渐变背景变成白色 渐变必须用 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 不正确
图片不显示 / <img src> 仍是 @path @ 占位符只在 +create --slides 中替换;直接调 xml_presentation.slide.create 必须先用 +media-uploadfile_token 写进 src
上传图片报 1061002 params error parent_type 必须是 slide_file(slides 唯一接受值);不要手拼,用 slides +media-upload

参考文档

文档 说明
lark-slides-create.md +create Shortcut:创建 PPT(支持 --slides 一步添加页面,含 @ 占位符自动上传图片)
lark-slides-media-upload.md +media-upload Shortcut:上传本地图片,返回 file_token
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.xmllark-cli schema slides.<resource>.<method> 输出不一致,以后两者为准。

同梱ファイル

※ ZIPに含まれるファイル一覧。`SKILL.md` 本体に加え、参考資料・サンプル・スクリプトが入っている場合があります。