lark-sheets
Lark Sheetsは、飛書(Lark)の電子スプレッドシートを操作し、作成、データ読み書き、検索、エクスポートなどを行い、大量のデータ処理や既存シートの活用を支援するSkill。
📜 元の英語説明(参考)
飞书电子表格:创建和操作电子表格。创建表格并写入表头和数据、读取和写入单元格、追加行数据、在已知电子表格中查找单元格内容、导出表格文件。当用户需要创建电子表格、批量读写数据、在已知表格中查找内容、导出或下载表格时使用。若用户是想按名称或关键词搜索云空间里的表格文件,请改用 lark-doc 的 docs +search 先定位资源。
🇯🇵 日本人クリエイター向け解説
Lark Sheetsは、飛書(Lark)の電子スプレッドシートを操作し、作成、データ読み書き、検索、エクスポートなどを行い、大量のデータ処理や既存シートの活用を支援するSkill。
※ jpskill.com 編集部が日本のビジネス現場向けに補足した解説です。Skill本体の挙動とは独立した参考情報です。
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o lark-sheets.zip https://jpskill.com/download/19588.zip && unzip -o lark-sheets.zip && rm lark-sheets.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/19588.zip -OutFile "$d\lark-sheets.zip"; Expand-Archive "$d\lark-sheets.zip" -DestinationPath $d -Force; ri "$d\lark-sheets.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
lark-sheets.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
lark-sheetsフォルダができる - 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
- 同梱ファイル
- 8
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
sheets (v3)
重要 — 開始する前に、../lark-shared/SKILL.md を必ず Read ツールで読み込んでください。これには認証と権限処理に関する情報が含まれています。
迅速な意思決定
- クラウドスペース内のスプレッドシートファイルをタイトルまたはキーワードで検索するには、まず
lark-cli docs +searchを使用します。 docs +searchは直接SHEETの結果を返しますので、ドキュメント/Wiki のみ検索できると誤解しないでください。- スプレッドシートの URL / トークンが分かっている場合は、
sheets +info、sheets +read、sheets +findなどのオブジェクト内部操作に進んでください。
コアコンセプト
ドキュメントタイプとトークン
飛書オープンプラットフォームでは、異なるタイプのドキュメントには異なる 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 (直接使用)
操作フロー(重要):
-
create — フィルターを作成します
- 初めてフィルターを作成する場合に使用します
- ⚠️
rangeは、フィルターを適用するすべての列をカバーする必要があります(例:B1:E200) - 既存のフィルターがある場合、
createを再度使用するとフィルター全体が上書きされます
-
update — フィルターを更新します
- 既存のフィルターに指定された列の条件を追加/更新する場合に使用します
colとconditionのみを指定すればよく、rangeは不要です
-
delete — フィルターを削除します
-
get — フィルターの状態を取得します
複数列フィルターの例:
メディア名(B列)と感情分析(E列)の二重フィルターを作成します。
# 1. 既存のフィルターを削除します(もしあれば)
lark-cli sheets spreadsheet.sheet.filters delete \
--params '{"spreadsheet_token":"<spreadsheet_token>","sheet_id":"<sheet_id>"}'
# 2. 最初のフィルターを作成します。range はフィルターを適用するすべての列をカバーします。
lark-cli sheets spreadsheet.sheet.filters create \
--params '{"spreadsheet_token":"<spreadsheet_token>","sheet_id":"<sheet_id>"}' \
--data '{"col":"B","condition":{"expected":["xx"],"filter_type":"multiValue"},"range":"<sheet_id>!B1:E200"}'
# 3. 2番目のフィルター条件を追加します
lark-cli sheets spreadsheet.sheet.filters update \
--params '{"spreadsheet_token":"<spreadsheet_token>","sheet_id":"<sheet_id>"}' \
--data '{"col":"E","condition":{"expected":["xx"],"filter_type":"multiValue"}}'
よくあるエラー:
Wrong Filter Value:フィルターが既に存在する場合、まずdeleteしてからcreateする必要がありますExcess Limit:update時に同じ列の条件を繰り返し追加した場合
Shortcuts(優先的に使用することを推奨)
Shortcut は、よく使用される操作を高度にカプセル化したものです(lark-cli sheets +<verb> [flags])。Shortcut がある操作は優先的に使用してください。
| Shortcut | 説明 |
|---|---|
+info |
スプレッドシートとシートの情報を表示します |
+read |
スプレッドシートのセル値を読み取ります |
+write |
スプレッドシートのセルに書き込みます(上書きモード) |
+append |
スプレッドシートに行を追加します |
+find |
スプレッドシート内のセルを検索します |
+create |
スプレッドシートを作成します(オプションでヘッダー行と初期データ) |
+export |
スプレッドシートをエクスポートします(非同期タスクポーリング + オプションでダウンロード) |
API リソース
lark-cli schema sheets.<resource>.<method> # API を呼び出す前に、まずパラメータ構造を確認する必要があります
lark-cli sheets <resource> <method> [flags] # API を呼び出します
重要:ネイティブ API を使用する場合、
--data/--paramsパラメータ構造を確認するために、まずschemaを実行する必要があります。フィールドの形式を推測しないでください。
spreadsheets
create— スプレッドシートを作成しますget— スプレッドシート情報を取得しますpatch— スプレッドシートのプロパティを変更します
spreadsheet.sheet.filters
create— フィルターを作成しますdelete— フィルターを削除しますget— フィルターを取得しますupdate— フィルターを更新します
spreadsheet.sheets
find— セルを検索します
権限表
| メソッド | 必要なスコープ |
|---|---|
spreadsheets.create |
sheets:spreadsheet:create |
spreadsheets.get |
sheets:spreadsheet.meta:read |
spreadsheets.patch |
sheets:spreadsheet.meta:write_only |
spreadsheet.sheet.filters.create |
sheets:spreadsheet:write_only |
spreadsheet.sheet.filters.delete |
sheets:spreadsheet:write_only |
spreadsheet.sheet.filters.get |
sheets:spreadsheet:read |
spreadsheet.sheet.filters.update |
sheets:spreadsheet:write_only |
spreadsheet.sheets.find |
sheets:spreadsheet:read |
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
sheets (v3)
CRITICAL — 开始前 MUST 先用 Read 工具读取 ../lark-shared/SKILL.md,其中包含认证、权限处理
快速决策
- 按标题或关键词找云空间里的表格文件,先用
lark-cli docs +search。 docs +search会直接返回SHEET结果,不要把它误解成只能搜文档 / Wiki。- 已知 spreadsheet URL / token 后,再进入
sheets +info、sheets +read、sheets +find等对象内部操作。
核心概念
文档类型与 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 (直接使用)
操作流程(重要):
-
create — 创建筛选
- 用于首次创建筛选
- ⚠️ range 必须覆盖所有需要筛选的列(如 B1:E200)
- 如果已有筛选存在,再用 create 会覆盖整个筛选
-
update — 更新筛选
- 用于在已有筛选上添加/更新指定列的条件
- 只需指定 col 和 condition,不需要 range
-
delete — 删除筛选
-
get — 获取筛选状态
多列筛选示例:
创建媒体名称(B列)和情感分析(E列)的双重筛选:
# 1. 删除现有筛选(如有)
lark-cli sheets spreadsheet.sheet.filters delete \
--params '{"spreadsheet_token":"<spreadsheet_token>","sheet_id":"<sheet_id>"}'
# 2. 创建第一个筛选,range 覆盖所有要筛选的列
lark-cli sheets spreadsheet.sheet.filters create \
--params '{"spreadsheet_token":"<spreadsheet_token>","sheet_id":"<sheet_id>"}' \
--data '{"col":"B","condition":{"expected":["xx"],"filter_type":"multiValue"},"range":"<sheet_id>!B1:E200"}'
# 3. 添加第二个筛选条件
lark-cli sheets spreadsheet.sheet.filters update \
--params '{"spreadsheet_token":"<spreadsheet_token>","sheet_id":"<sheet_id>"}' \
--data '{"col":"E","condition":{"expected":["xx"],"filter_type":"multiValue"}}'
常见错误:
Wrong Filter Value:筛选已存在,需要先 delete 再 createExcess Limit:update 时重复添加同一列条件
Shortcuts(推荐优先使用)
Shortcut 是对常用操作的高级封装(lark-cli sheets +<verb> [flags])。有 Shortcut 的操作优先使用。
| Shortcut | 说明 |
|---|---|
+info |
View spreadsheet and sheet information |
+read |
Read spreadsheet cell values |
+write |
Write to spreadsheet cells (overwrite mode) |
+append |
Append rows to a spreadsheet |
+find |
Find cells in a spreadsheet |
+create |
Create a spreadsheet (optional header row and initial data) |
+export |
Export a spreadsheet (async task polling + optional download) |
API Resources
lark-cli schema sheets.<resource>.<method> # 调用 API 前必须先查看参数结构
lark-cli sheets <resource> <method> [flags] # 调用 API
重要:使用原生 API 时,必须先运行
schema查看--data/--params参数结构,不要猜测字段格式。
spreadsheets
create— 创建电子表格get— 获取电子表格信息patch— 修改电子表格属性
spreadsheet.sheet.filters
create— 创建筛选delete— 删除筛选get— 获取筛选update— 更新筛选
spreadsheet.sheets
find— 查找单元格
权限表
| 方法 | 所需 scope |
|---|---|
spreadsheets.create |
sheets:spreadsheet:create |
spreadsheets.get |
sheets:spreadsheet.meta:read |
spreadsheets.patch |
sheets:spreadsheet.meta:write_only |
spreadsheet.sheet.filters.create |
sheets:spreadsheet:write_only |
spreadsheet.sheet.filters.delete |
sheets:spreadsheet:write_only |
spreadsheet.sheet.filters.get |
sheets:spreadsheet:read |
spreadsheet.sheet.filters.update |
sheets:spreadsheet:write_only |
spreadsheet.sheets.find |
sheets:spreadsheet:read |
同梱ファイル
※ ZIPに含まれるファイル一覧。`SKILL.md` 本体に加え、参考資料・サンプル・スクリプトが入っている場合があります。
- 📄 SKILL.md (7,924 bytes)
- 📎 references/lark-sheets-append.md (1,966 bytes)
- 📎 references/lark-sheets-create.md (3,260 bytes)
- 📎 references/lark-sheets-export.md (1,868 bytes)
- 📎 references/lark-sheets-find.md (2,571 bytes)
- 📎 references/lark-sheets-info.md (1,323 bytes)
- 📎 references/lark-sheets-read.md (2,438 bytes)
- 📎 references/lark-sheets-write.md (2,265 bytes)