lark-drive
飛書(Lark)のクラウドストレージにあるファイルをアップロード・ダウンロードしたり、フォルダを作成・移動・削除したり、ファイルの権限やコメントを管理したりするなど、クラウド上のファイルを効率的に管理するSkill。
📜 元の英語説明(参考)
飞书云空间:管理云空间中的文件和文件夹。上传和下载文件、创建文件夹、复制/移动/删除文件、查看文件元数据、管理文档评论、管理文档权限、订阅用户评论变更事件。当用户需要上传或下载文件、整理云空间目录、查看文件详情、管理评论、管理文档权限、订阅用户评论变更事件时使用。
🇯🇵 日本人クリエイター向け解説
飛書(Lark)のクラウドストレージにあるファイルをアップロード・ダウンロードしたり、フォルダを作成・移動・削除したり、ファイルの権限やコメントを管理したりするなど、クラウド上のファイルを効率的に管理するSkill。
※ jpskill.com 編集部が日本のビジネス現場向けに補足した解説です。Skill本体の挙動とは独立した参考情報です。
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o lark-drive.zip https://jpskill.com/download/19579.zip && unzip -o lark-drive.zip && rm lark-drive.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/19579.zip -OutFile "$d\lark-drive.zip"; Expand-Archive "$d\lark-drive.zip" -DestinationPath $d -Force; ri "$d\lark-drive.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
lark-drive.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
lark-driveフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-18
- 取得日時
- 2026-05-18
- 同梱ファイル
- 4
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
drive (v1)
重要 — 開始前に、認証と権限処理を含む ../lark-shared/SKILL.md を必ず Read ツールで読み込んでください。
核心概念
ドキュメントタイプとトークン
飛書オープンプラットフォームでは、異なるタイプのドキュメントには異なる URL 形式とトークン処理方法があります。ドキュメント操作(コメントの追加、ファイルのダウンロードなど)を行う際には、まず正しい file_token を取得する必要があります。
ドキュメント URL 形式とトークン処理
| URL 形式 | 例 | トークンタイプ | 処理方法 |
|---|---|---|---|
/docx/ |
https://example.larksuite.com/docx/doxcnxxxxxxxxx |
file_token |
URL パス内のトークンを file_token として直接使用します |
/doc/ |
https://example.larksuite.com/doc/doccnxxxxxxxxx |
file_token |
URL パス内のトークンを file_token として直接使用します |
/wiki/ |
https://example.larksuite.com/wiki/wikcnxxxxxxxxx |
wiki_token |
⚠️ 直接使用できません。まず実際の obj_token を照会して取得する必要があります |
/sheets/ |
https://example.larksuite.com/sheets/shtcnxxxxxxxxx |
file_token |
URL パス内のトークンを file_token として直接使用します |
/drive/folder/ |
https://example.larksuite.com/drive/folder/fldcnxxxx |
folder_token |
URL パス内のトークンをフォルダトークンとして使用します |
Wiki リンクの特殊処理(重要!)
ナレッジベースリンク(/wiki/TOKEN)の背後には、クラウドドキュメント、スプレッドシート、多次元テーブルなど、さまざまな種類のドキュメントが存在する可能性があります。URL 内のトークンが file_token であると直接仮定することはできません。実際のタイプと実際のトークンを照会する必要があります。
処理フロー
-
wiki.spaces.get_nodeを使用してノード情報を照会しますlark-cli wiki spaces get_node --params '{"token":"wiki_token"}' -
返された結果から重要な情報を抽出します
node.obj_type:ドキュメントタイプ(docx/doc/sheet/bitable/slides/file/mindnote)node.obj_token:実際のドキュメントトークン(後続の操作に使用)node.title:ドキュメントタイトル
-
obj_typeに基づいて対応する API を使用しますobj_type 説明 使用する API docx新しいバージョンのクラウドドキュメント drive file.comments.*、docx.*doc古いバージョンのクラウドドキュメント drive file.comments.*sheetスプレッドシート sheets.*bitable多次元テーブル bitable.*slidesスライド drive.*fileファイル drive.*mindnoteマインドマップ drive.*
照会例
# wiki ノードを照会します
lark-cli wiki spaces get_node --params '{"token":"wiki_token"}'
返された結果の例:
{
"node": {
"obj_type": "docx",
"obj_token": "xxxx",
"title": "タイトル",
"node_type": "origin",
"space_id": "12345678910"
}
}
リソース関係
Wiki Space (知識空間)
└── Wiki Node (知識ベースノード)
├── obj_type: docx (新しいバージョンのドキュメント)
│ └── obj_token (実際のドキュメントトークン)
├── obj_type: doc (古いバージョンのドキュメント)
│ └── obj_token (実際のドキュメントトークン)
├── obj_type: sheet (スプレッドシート)
│ └── obj_token (実際のドキュメントトークン)
├── obj_type: bitable (多次元テーブル)
│ └── obj_token (実際のドキュメントトークン)
└── obj_type: file/slides/mindnote
└── obj_token (実際のドキュメントトークン)
Drive Folder (クラウドスペースフォルダ)
└── File (ファイル/ドキュメント)
└── file_token (直接使用)
一般的な操作のトークン要件
| 操作 | 必要なトークン | 説明 |
|---|---|---|
| ドキュメントコンテンツの読み取り | file_token / docs +fetch による自動処理 |
docs +fetch は URL を直接渡すことをサポートしています |
| 部分コメントの追加(選択範囲コメント) | file_token |
--selection-with-ellipsis または --block-id を渡すと、drive +add-comment は部分コメントを作成します。docx、および最終的に docx に解決される wiki URL のみをサポートします |
| 全文コメントの追加 | file_token |
--selection-with-ellipsis / --block-id を渡さない場合、drive +add-comment はデフォルトで全文コメントを作成します。docx、古いバージョンの doc URL、および最終的に doc/docx に解決される wiki URL をサポートします |
| ファイルのダウンロード | file_token |
ファイル URL から直接抽出します |
| ファイルのアップロード | folder_token / wiki_node_token |
ターゲット位置のトークン |
| ドキュメントコメントのリスト表示 | file_token |
コメントの追加と同じです |
コメント機能の境界(重要!)
drive +add-commentは2つのモードをサポートしています。- 全文コメント:
--selection-with-ellipsis/--block-idが渡されない場合にデフォルトで有効になります。--full-commentを明示的に渡すこともできます。docx、古いバージョンのdocURL、および最終的にdoc/docxに解決される wiki URL をサポートします。 - 部分コメント:
--selection-with-ellipsisまたは--block-idが渡された場合に有効になります。docx、および最終的にdocxに解決される wiki URL のみをサポートします。 drive +add-commentの--contentにはreply_elementsJSON 配列文字列を渡す必要があります。例:--content '[{"type":"text","text":"正文"}]'。- wiki が解析後に
doc/docxでない場合、+add-commentを使用しないでください。 - より低レベルでコメント V2 プロトコルを直接呼び出す必要がある場合は、ネイティブ API を使用します。まず
lark-cli schema drive.file.comments.create_v2を実行し、次にlark-cli drive file.comments create_v2 ...を実行します。全文コメントはanchorを省略し、部分コメントはanchor.block_idを渡します。
コメントの照会と統計基準(重要!)
- ドキュメントコメントを照会する際は、
drive file.comments listを使用します。 drive file.comments listが返すitemsは「コメントカード」のリストとして理解されるべきであり、各itemはユーザーインターフェースに表示される1枚のコメントカードに対応し、フラットなインタラクションメッセージリストではありません。- サーバー側のセマンティクスでは、最初のコメントが作成されると同時に、そのカード内の最初の返信も作成されます。したがって、本文を実際に保持しているのは各
item.reply_list.repliesであり、その最初の返信はユーザーの視点から見ると、そのカード内の「コメント自体」です。 - ユーザーが「コメント数」または「コメントカード数」を統計したい場合、
itemsの長さを統計すれば十分です。全量統計の場合は、すべてのコメントページングで返されるitemsの長さを累積します。 - ユーザーが「返信数」を統計したい場合、ユーザーの視点からは各コメントカード内の最初のコメントを除外すべきであり、統計基準はすべての
item.reply_list.repliesの長さの合計からitemsの長さを引いたものです。 - ユーザーが「総インタラクション数」を統計したい場合、すべての
item.reply_list.repliesの長さの合計を統計すれば十分です。この基準には各コメントカード内の最初のコメントが含まれます。 - ある
item.has_more=trueの場合、そのコメントカードの下にさらに多くの返信が現在の返信に含まれていないことを意味します。この場合、drive file.comment.replys listを呼び出してすべて取得し、その後、全量返信数 / 総インタラクション数を統計する必要があります。
コメントのビジネス特性とガイダンス(重要!)
コメントの並べ替えガイダンス
- ドキュメントには通常複数のコメントがあり、コメントは
create_time(作成時間)で並べ替えられます。 - 重要:ユーザーが「最新コメント」、「最後のコメント」、「最も古いコメント」を明確に言及した場合にのみ、
create_timeに基づいて並べ替える必要があります。- まずすべてのコメントを取得する必要があります(ページング処理で全データを取得する)。1ページだけ取得して並べ替えることはできません。
- 「最新コメント」 / 「最後のコメント」:
create_timeの降順で並べ替え、最初の1件を取得します。 - 「最も古いコメント」:
create_timeの昇順で並べ替え、最初の1件を取得します。
- ユーザーが「最初のコメント」とだけ言った場合、
drive file.comments listが返す最初のコメントをそのまま使用すればよく、追加の並べ替えは不要です。
コメント返信の制限
- コメント返信を追加する前に、以下の制限があるか確認してください。
- 全文コメントは返信をサポートしていません:
is_whole=trueのコメント(全文コメント)には返信を追加できません。このようなコメントに遭遇した場合は、ユーザーに「全文コメントは返信をサポートしていません」と伝えるべきです。 - 解決済みのコメントは返信をサポートしていません:
is_solved=trueのコメントには返信を追加できません。このようなコメントに遭遇した場合は、ユーザーに「このコメントは解決済みのため、返信できません」と伝えるべきです。 - 注意:ユーザーが特定のコメントに返信しようとしたが、そのコメントが上記の制限により返信できない場合、返信できないことを伝えるだけで十分です。ユーザーの期待に反する可能性があるため、自動的に他の返信可能なコメントを探さないでください。
一括照会とリスト照会の選択
drive file.comments batch_queryの使用は、コメント ID が既知の場合の一括照会であり、具体的なコメント ID のリストを渡す必要があります。drive file.comments listの使用は、コメントリストをページングで取得するために使用され、コメント総数の統計、すべてのコメントの走査、または「最新/最後の N 件のコメント」などのシナリオに適しています。
典型的なエラーと解決策
| エラーメッセージ | 原因 | 解決策 |
|---|---|---|
not exist |
誤ったトークンを使用しました | トークンタイプを確認してください。wiki リンクはまず obj_token を照会して取得する必要があります |
permission denied |
関連する操作権限がありません | ユーザーに、現在の身元がドキュメント/ファイルに対して適切な操作権限を持っているか確認するよう促してください。必要であれば、適切な権限を付与できます |
invalid file_type |
file_type パラメータが誤っています |
obj_type に基づいて正しい file_type(docx/doc/sheet)を渡してください |
Shortcuts(優先的に使用することを推奨)
Shortcut は、一般的な操作を高度にカプセル化したものです(lark-cli drive +<verb> [flags])。Shortcut がある操作は優先的に使用してください。
| Shortcut | 説明 |
|---|---|
+upload |
ローカルファイルを Drive にアップロードします |
+download |
Drive からローカルにファイルをダウンロードします |
+add-comment |
ドキュメント全体にコメントを追加するか、選択した docx テキストにローカルコメントを追加します(doc/docx に解決される wiki URL もサポートします) |
API Resources
`
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
drive (v1)
CRITICAL — 开始前 MUST 先用 Read 工具读取 ../lark-shared/SKILL.md,其中包含认证、权限处理
核心概念
文档类型与 Token
飞书开放平台中,不同类型的文档有不同的 URL 格式和 Token 处理方式。在进行文档操作(如添加评论、下载文件等)时,必须先获取正确的 file_token。
文档 URL 格式与 Token 处理
| URL 格式 | 示例 | Token 类型 | 处理方式 |
|---|---|---|---|
/docx/ |
https://example.larksuite.com/docx/doxcnxxxxxxxxx |
file_token |
URL 路径中的 token 直接作为 file_token 使用 |
/doc/ |
https://example.larksuite.com/doc/doccnxxxxxxxxx |
file_token |
URL 路径中的 token 直接作为 file_token 使用 |
/wiki/ |
https://example.larksuite.com/wiki/wikcnxxxxxxxxx |
wiki_token |
⚠️ 不能直接使用,需要先查询获取真实的 obj_token |
/sheets/ |
https://example.larksuite.com/sheets/shtcnxxxxxxxxx |
file_token |
URL 路径中的 token 直接作为 file_token 使用 |
/drive/folder/ |
https://example.larksuite.com/drive/folder/fldcnxxxx |
folder_token |
URL 路径中的 token 作为文件夹 token 使用 |
Wiki 链接特殊处理(关键!)
知识库链接(/wiki/TOKEN)背后可能是云文档、电子表格、多维表格等不同类型的文档。不能直接假设 URL 中的 token 就是 file_token,必须先查询实际类型和真实 token。
处理流程
-
使用
wiki.spaces.get_node查询节点信息lark-cli wiki spaces get_node --params '{"token":"wiki_token"}' -
从返回结果中提取关键信息
node.obj_type:文档类型(docx/doc/sheet/bitable/slides/file/mindnote)node.obj_token:真实的文档 token(用于后续操作)node.title:文档标题
-
根据
obj_type使用对应的 APIobj_type 说明 使用的 API docx新版云文档 drive file.comments.*、docx.*doc旧版云文档 drive file.comments.*sheet电子表格 sheets.*bitable多维表格 bitable.*slides幻灯片 drive.*file文件 drive.*mindnote思维导图 drive.*
查询示例
# 查询 wiki 节点
lark-cli wiki spaces get_node --params '{"token":"wiki_token"}'
返回结果示例:
{
"node": {
"obj_type": "docx",
"obj_token": "xxxx",
"title": "标题",
"node_type": "origin",
"space_id": "12345678910"
}
}
资源关系
Wiki Space (知识空间)
└── Wiki Node (知识库节点)
├── obj_type: docx (新版文档)
│ └── obj_token (真实文档 token)
├── obj_type: doc (旧版文档)
│ └── obj_token (真实文档 token)
├── obj_type: sheet (电子表格)
│ └── obj_token (真实文档 token)
├── obj_type: bitable (多维表格)
│ └── obj_token (真实文档 token)
└── obj_type: file/slides/mindnote
└── obj_token (真实文档 token)
Drive Folder (云空间文件夹)
└── File (文件/文档)
└── file_token (直接使用)
常见操作 Token 需求
| 操作 | 需要的 Token | 说明 |
|---|---|---|
| 读取文档内容 | file_token / 通过 docs +fetch 自动处理 |
docs +fetch 支持直接传入 URL |
| 添加局部评论(划词评论) | file_token |
传 --selection-with-ellipsis 或 --block-id 时,drive +add-comment 会创建局部评论;仅支持 docx,以及最终解析为 docx 的 wiki URL |
| 添加全文评论 | file_token |
不传 --selection-with-ellipsis / --block-id 时,drive +add-comment 默认创建全文评论;支持 docx、旧版 doc URL,以及最终解析为 doc/docx 的 wiki URL |
| 下载文件 | file_token |
从文件 URL 中直接提取 |
| 上传文件 | folder_token / wiki_node_token |
目标位置的 token |
| 列出文档评论 | file_token |
同添加评论 |
评论能力边界(关键!)
drive +add-comment支持两种模式。- 全文评论:未传
--selection-with-ellipsis/--block-id时默认启用,也可显式传--full-comment;支持docx、旧版docURL,以及最终解析为doc/docx的 wiki URL。 - 局部评论:传
--selection-with-ellipsis或--block-id时启用;仅支持docx,以及最终解析为docx的 wiki URL。 drive +add-comment的--content需要传reply_elementsJSON 数组字符串,例如--content '[{"type":"text","text":"正文"}]'。- 如果 wiki 解析后不是
doc/docx,不要用+add-comment。 - 如果需要更底层地直接调用评论 V2 协议,再走原生 API:先执行
lark-cli schema drive.file.comments.create_v2,再执行lark-cli drive file.comments create_v2 ...。全文评论省略anchor,局部评论传anchor.block_id。
评论查询与统计口径(关键!)
- 查询文档评论时,使用
drive file.comments list。 drive file.comments list返回的items应理解为"评论卡片"列表,每个item对应用户界面里看到的一张评论卡片,而不是平铺的互动消息列表。- 服务端语义上,创建第一条评论时会同时创建该卡片里的第一条 reply;因此真正承载正文的是每个
item.reply_list.replies,其中第一条 reply 在用户视角下就是这张卡片里的"评论本身"。 - 当用户要统计"评论数"或"评论卡片数"时,统计
items的长度即可;如果是全量统计,则对所有评论分页返回的items长度累加。 - 当用户要统计"回复数"时,按用户视角应排除每张评论卡片里的首条评论,统计口径是所有
item.reply_list.replies的长度之和减去items的长度。 - 当用户要统计"总互动数"时,统计所有
item.reply_list.replies的长度之和即可;这个口径包含每张评论卡片里的首条评论。 - 如果某个
item.has_more=true,说明该评论卡片下还有更多回复未包含在当前返回中;此时需要继续调用drive file.comment.replys list拉全后,再做全量回复数 / 总互动数统计。
评论业务特性与引导(关键!)
评论排序引导
- 一个文档通常有多个评论,评论按
create_time(创建时间)排序。 - 重要:只有当用户明确提到"最新评论"、"最后评论"、"最早评论"时,才需要根据
create_time进行排序:- 必须先获取所有评论(处理分页拉完所有数据),不能只获取一页就排序
- "最新评论" / "最后评论":按
create_time降序排列,取第一条 - "最早评论":按
create_time升序排列,取第一条
- 如果用户只说"第一条评论",直接使用
drive file.comments list返回的第一条即可,不需要额外排序。
评论回复限制
- 添加评论回复前先检查是否存在以下限制
- 全文评论不支持回复:
is_whole=true的评论(全文评论)无法添加回复,遇到此类评论应提示用户"全文评论不支持回复"。 - 已解决评论不支持回复:
is_solved=true的评论无法添加回复,遇到此类评论应提示用户"该评论已被解决,无法回复"。 - 注意:当用户要回复某条评论但该评论因上述限制不能回复时,只提示不能回复即可,不要自动帮用户找其他可以回复的评论,避免不符合用户预期。
批量查询与列表查询的选择
- 使用
drive file.comments batch_query是已知评论 ID 后的批量查询,需要传入具体的评论 ID 列表。 - 使用
drive file.comments list用于分页获取评论列表,适合统计评论总数、遍历所有评论,或获取"最新/最后 N 条评论"等场景。
典型错误与解决方案
| 错误信息 | 原因 | 解决方案 |
|---|---|---|
not exist |
使用了错误的 token | 检查 token 类型,wiki 链接必须先查询获取 obj_token |
permission denied |
没有相关操作权限 | 引导用户检查当前身份对文档/文件是否有相应操作权限;如果需要,可以授予相应权限 |
invalid file_type |
file_type 参数错误 | 根据 obj_type 传入正确的 file_type(docx/doc/sheet) |
Shortcuts(推荐优先使用)
Shortcut 是对常用操作的高级封装(lark-cli drive +<verb> [flags])。有 Shortcut 的操作优先使用。
| Shortcut | 说明 |
|---|---|
+upload |
Upload a local file to Drive |
+download |
Download a file from Drive to local |
+add-comment |
Add a full-document comment, or a local comment to selected docx text (also supports wiki URL resolving to doc/docx) |
API Resources
lark-cli schema drive.<resource>.<method> # 调用 API 前必须先查看参数结构
lark-cli drive <resource> <method> [flags] # 调用 API
重要:使用原生 API 时,必须先运行
schema查看--data/--params参数结构,不要猜测字段格式。
files
copy— 复制文件
file.comments
batch_query— 批量获取评论create_v2— 添加全文/局部(划词)评论list— 分页获取文档评论patch— 解决/恢复 评论
file.comment.replys
create—delete— 删除回复list— 获取回复update— 更新回复
permission.members
auth—create— 增加协作者权限transfer_owner—
metas
batch_query— 获取文档元数据
user
remove_subscription— 取消订阅用户、应用维度事件subscription— 订阅用户、应用维度事件(本次开放评论添加事件)subscription_status— 查询用户、应用对指定事件的订阅状态
权限表
| 方法 | 所需 scope |
|---|---|
files.copy |
docs:document:copy |
file.comments.batch_query |
docs:document.comment:read |
file.comments.create_v2 |
docs:document.comment:create |
file.comments.list |
docs:document.comment:read |
file.comments.patch |
docs:document.comment:update |
file.comment.replys.create |
docs:document.comment:create |
file.comment.replys.delete |
docs:document.comment:delete |
file.comment.replys.list |
docs:document.comment:read |
file.comment.replys.update |
docs:document.comment:update |
permission.members.auth |
docs:permission.member:auth |
permission.members.create |
docs:permission.member:create |
permission.members.transfer_owner |
docs:permission.member:transfer |
metas.batch_query |
drive:drive.metadata:readonly |
user.remove_subscription |
docs:event:subscribe |
user.subscription |
docs:event:subscribe |
user.subscription_status |
docs:event:subscribe |
同梱ファイル
※ ZIPに含まれるファイル一覧。`SKILL.md` 本体に加え、参考資料・サンプル・スクリプトが入っている場合があります。
- 📄 SKILL.md (11,903 bytes)
- 📎 references/lark-drive-add-comment.md (5,471 bytes)
- 📎 references/lark-drive-download.md (755 bytes)
- 📎 references/lark-drive-upload.md (3,196 bytes)