lark-sheets
Compare original and translation side by side
🇺🇸
Original
English🇨🇳
Translation
Chinesesheets (v3)
sheets (v3)
CRITICAL — 开始前 MUST 先用 Read 工具读取 ,其中包含认证、权限处理
../lark-shared/SKILL.md重要提示 — 开始前必须先用 Read 工具读取 ,其中包含认证、权限处理相关内容
../lark-shared/SKILL.md快速决策
快速决策
- 按标题或关键词找云空间里的表格文件,先用 。
lark-cli docs +search - 会直接返回
docs +search结果,不要把它误解成只能搜文档 / Wiki。SHEET - 已知 spreadsheet URL / token 后,再进入 、
sheets +info、sheets +read等对象内部操作。sheets +find
- 按标题或关键词找云空间里的表格文件,先用 。
lark-cli docs +search - 会直接返回
docs +search结果,不要把它误解成只能搜文档 / Wiki。SHEET - 已知 spreadsheet URL / token 后,再进入 、
sheets +info、sheets +read等对象内部操作。sheets +find
核心概念
核心概念
文档类型与 Token
文档类型与 Token
飞书开放平台中,不同类型的文档有不同的 URL 格式和 Token 处理方式。在进行文档操作(如添加评论、下载文件等)时,必须先获取正确的 。
file_token飞书开放平台中,不同类型的文档有不同的 URL 格式和 Token 处理方式。在进行文档操作(如添加评论、下载文件等)时,必须先获取正确的 。
file_token文档 URL 格式与 Token 处理
文档 URL 格式与 Token 处理
| URL 格式 | 示例 | Token 类型 | 处理方式 |
|---|---|---|---|
| | | URL 路径中的 token 直接作为 |
| | | URL 路径中的 token 直接作为 |
| | | ⚠️ 不能直接使用,需要先查询获取真实的 |
| | | URL 路径中的 token 直接作为 |
| | | URL 路径中的 token 作为文件夹 token 使用 |
| URL 格式 | 示例 | Token 类型 | 处理方式 |
|---|---|---|---|
| | | URL 路径中的 token 直接作为 |
| | | URL 路径中的 token 直接作为 |
| | | ⚠️ 不能直接使用,需要先查询获取真实的 |
| | | URL 路径中的 token 直接作为 |
| | | URL 路径中的 token 作为文件夹 token 使用 |
Wiki 链接特殊处理(关键!)
Wiki 链接特殊处理(关键!)
知识库链接()背后可能是云文档、电子表格、多维表格等不同类型的文档。不能直接假设 URL 中的 token 就是 file_token,必须先查询实际类型和真实 token。
/wiki/TOKEN知识库链接()背后可能是云文档、电子表格、多维表格等不同类型的文档。不能直接假设 URL 中的 token 就是 file_token,必须先查询实际类型和真实 token。
/wiki/TOKEN处理流程
处理流程
-
使用查询节点信息
wiki.spaces.get_nodebashlark-cli wiki spaces get_node --params '{"token":"wiki_token"}' -
从返回结果中提取关键信息
- :文档类型(docx/doc/sheet/bitable/slides/file/mindnote)
node.obj_type - :真实的文档 token(用于后续操作)
node.obj_token - :文档标题
node.title
-
根据使用对应的 API
obj_typeobj_type 说明 使用的 API docx新版云文档 、drive file.comments.*docx.*doc旧版云文档 drive file.comments.*sheet电子表格 sheets.*bitable多维表格 bitable.*slides幻灯片 drive.*file文件 drive.*mindnote思维导图 drive.*
-
使用查询节点信息
wiki.spaces.get_nodebashlark-cli wiki spaces get_node --params '{"token":"wiki_token"}' -
从返回结果中提取关键信息
- :文档类型(docx/doc/sheet/bitable/slides/file/mindnote)
node.obj_type - :真实的文档 token(用于后续操作)
node.obj_token - :文档标题
node.title
-
根据使用对应的 API
obj_typeobj_type 说明 使用的 API docx新版云文档 、drive file.comments.*docx.*doc旧版云文档 drive file.comments.*sheet电子表格 sheets.*bitable多维表格 bitable.*slides幻灯片 drive.*file文件 drive.*mindnote思维导图 drive.*
查询示例
查询示例
bash
undefinedbash
undefined查询 wiki 节点
查询 wiki 节点
lark-cli wiki spaces get_node --params '{"token":"wiki_token"}'
返回结果示例:
```json
{
"node": {
"obj_type": "docx",
"obj_token": "xxxx",
"title": "标题",
"node_type": "origin",
"space_id": "12345678910"
}
}lark-cli wiki spaces get_node --params '{"token":"wiki_token"}'
返回结果示例:
```json
{
"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列)的双重筛选:
bash
undefinedWiki 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列)的双重筛选:
bash
undefined1. 删除现有筛选(如有)
1. 删除现有筛选(如有)
lark-cli sheets spreadsheet.sheet.filters delete
--params '{"spreadsheet_token":"<spreadsheet_token>","sheet_id":"<sheet_id>"}'
--params '{"spreadsheet_token":"<spreadsheet_token>","sheet_id":"<sheet_id>"}'
lark-cli sheets spreadsheet.sheet.filters delete
--params '{"spreadsheet_token":"<spreadsheet_token>","sheet_id":"<sheet_id>"}'
--params '{"spreadsheet_token":"<spreadsheet_token>","sheet_id":"<sheet_id>"}'
2. 创建第一个筛选,range 覆盖所有要筛选的列
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"}'
--params '{"spreadsheet_token":"<spreadsheet_token>","sheet_id":"<sheet_id>"}'
--data '{"col":"B","condition":{"expected":["xx"],"filter_type":"multiValue"},"range":"<sheet_id>!B1:E200"}'
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"}'
--params '{"spreadsheet_token":"<spreadsheet_token>","sheet_id":"<sheet_id>"}'
--data '{"col":"B","condition":{"expected":["xx"],"filter_type":"multiValue"},"range":"<sheet_id>!B1:E200"}'
3. 添加第二个筛选条件
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"}}'
--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 时重复添加同一列条件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"}}'
--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(推荐优先使用)
Shortcuts(推荐优先使用)
Shortcut 是对常用操作的高级封装()。有 Shortcut 的操作优先使用。
lark-cli sheets +<verb> [flags]| Shortcut | 说明 |
|---|---|
| View spreadsheet and sheet information |
| Read spreadsheet cell values |
| Write to spreadsheet cells (overwrite mode) |
| Append rows to a spreadsheet |
| Find cells in a spreadsheet |
| Create a spreadsheet (optional header row and initial data) |
| Export a spreadsheet (async task polling + optional download) |
Shortcut 是对常用操作的高级封装()。有 Shortcut 的操作优先使用。
lark-cli sheets +<verb> [flags]| Shortcut | 说明 |
|---|---|
| 查看电子表格和工作表信息 |
| 读取电子表格单元格值 |
| 写入电子表格单元格(覆盖模式) |
| 向电子表格追加行数据 |
| 在电子表格中查找单元格 |
| 创建电子表格(可选表头行和初始数据) |
| 导出电子表格(异步任务轮询 + 可选下载) |
API Resources
API Resources
bash
lark-cli schema sheets.<resource>.<method> # 调用 API 前必须先查看参数结构
lark-cli sheets <resource> <method> [flags] # 调用 API重要:使用原生 API 时,必须先运行查看schema/--data参数结构,不要猜测字段格式。--params
bash
lark-cli schema sheets.<resource>.<method> # 调用 API 前必须先查看参数结构
lark-cli sheets <resource> <method> [flags] # 调用 API重要:使用原生 API 时,必须先运行查看schema/--data参数结构,不要猜测字段格式。--params
spreadsheets
spreadsheets
- — 创建电子表格
create- — 获取电子表格信息
get - — 修改电子表格属性
patch
- — 创建电子表格
create- — 获取电子表格信息
get - — 修改电子表格属性
patch
spreadsheet.sheet.filters
spreadsheet.sheet.filters
- — 创建筛选
create- — 删除筛选
delete - — 获取筛选
get - — 更新筛选
update
- — 创建筛选
create- — 删除筛选
delete - — 获取筛选
get - — 更新筛选
update
spreadsheet.sheets
spreadsheet.sheets
- — 查找单元格
find
- — 查找单元格
find
权限表
权限表
| 方法 | 所需 scope |
|---|---|
| |
| |
| |
| |
| |
| |
| |
| |
| 方法 | 所需 scope |
|---|---|
| |
| |
| |
| |
| |
| |
| |
| |