Cli lark-sheets
飞书电子表格:创建和操作电子表格。创建表格并写入表头和数据、读取和写入单元格、追加行数据、在已知电子表格中查找单元格内容、导出表格文件。当用户需要创建电子表格、批量读写数据、在已知表格中查找内容、导出或下载表格时使用。若用户是想按名称或关键词搜索云空间里的表格文件,请改用 lark-doc 的 docs +search 先定位资源。
install
source · Clone the upstream repo
git clone https://github.com/larksuite/cli
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/larksuite/cli "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/lark-sheets" ~/.claude/skills/larksuite-cli-lark-sheets && rm -rf "$T"
manifest:
skills/lark-sheets/SKILL.mdsource content
sheets (v3)
CRITICAL — 开始前 MUST 先用 Read 工具读取
,其中包含认证、权限处理../lark-shared/SKILL.md
快速决策
- 按标题或关键词找云空间里的表格文件,先用
。lark-cli docs +search
会直接返回docs +search
结果,不要把它误解成只能搜文档 / Wiki。SHEET- 已知 spreadsheet URL / token 后,再进入
、sheets +info
、sheets +read
等对象内部操作。sheets +find
核心概念
文档类型与 Token
飞书开放平台中,不同类型的文档有不同的 URL 格式和 Token 处理方式。在进行文档操作(如添加评论、下载文件等)时,必须先获取正确的
file_token。
文档 URL 格式与 Token 处理
| URL 格式 | 示例 | Token 类型 | 处理方式 |
|---|---|---|---|
| | | URL 路径中的 token 直接作为 使用 |
| | | URL 路径中的 token 直接作为 使用 |
| | | ⚠️ 不能直接使用,需要先查询获取真实的 |
| | | URL 路径中的 token 直接作为 使用 |
| | | URL 路径中的 token 作为文件夹 token 使用 |
Wiki 链接特殊处理(关键!)
知识库链接(
/wiki/TOKEN)背后可能是云文档、电子表格、多维表格等不同类型的文档。不能直接假设 URL 中的 token 就是 file_token,必须先查询实际类型和真实 token。
处理流程
-
使用
查询节点信息wiki.spaces.get_nodelark-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
-
根据
使用对应的 APIobj_typeobj_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"}}'
常见错误:
:筛选已存在,需要先 delete 再 createWrong Filter Value
:update 时重复添加同一列条件Excess Limit
单元格数据类型
接受二维数组的 shortcut(
+write/+append 的 --values、+create 的 --data)中,每个单元格值支持以下类型。公式、带文本链接、@人、@文档、下拉列表必须使用对象格式,直接传字符串会被当作纯文本存储。
| 类型 | 写入格式 | 示例 |
|---|---|---|
| 字符串 | | |
| 数字 | | 、 |
| 日期 | (自 1899-12-30 起的天数,需先设单元格日期格式) | |
| 链接(纯 URL) | | |
| 链接(带文本) | | |
| 邮箱 | | |
| 公式 | | |
| @人 | | (notify 可选,默认 false;仅在用户明确要求通知时设为 true) |
| @文档 | | |
| 下拉列表 | | |
写入公式示例:
# ✅ 正确:使用对象格式 lark-cli sheets +write --url "URL" --sheet-id "sheetId" --range "C6" \ --values '[[{"type":"formula","text":"=SUM(C2:C5)"}]]' # ❌ 错误:直接传字符串,会被存为纯文本 lark-cli sheets +write --url "URL" --sheet-id "sheetId" --range "C6" \ --values '[["=SUM(C2:C5)"]]'
公式语法参考:涉及 ARRAYFORMULA、原生数组函数、MAP/LAMBDA、日期差、Excel 公式改写等飞书特有规则时,先阅读
。references/lark-sheets-formula.md
限制:
- 公式支持 IMPORTRANGE 跨表引用(最多 5 层嵌套、每个工作表最多 100 个引用)
- @人仅支持同租户用户,单次最多 50 人
- 下拉列表需先配置下拉选项,否则
写入会变成纯文本。配置方法见multipleValue
。值中的字符串不能包含逗号references/lark-sheets-set-dropdown.md
Shortcuts(推荐优先使用)
Shortcut 是对常用操作的高级封装(
lark-cli sheets +<verb> [flags])。有 Shortcut 的操作优先使用。
| Shortcut | 说明 |
|---|---|
| View spreadsheet and sheet information |
| Read spreadsheet cell values |
| Write to spreadsheet cells (overwrite mode) |
| Write an image into a spreadsheet cell |
| 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) |
| Merge cells in a spreadsheet |
| Unmerge (split) cells in a spreadsheet |
| Find and replace cell values |
| Set cell style for a range |
| Batch set cell styles for multiple ranges |
| Add rows or columns at the end of a sheet |
| Insert rows or columns at a specified position |
| Update row or column properties (visibility, size) |
| Move rows or columns to a new position |
| Delete rows or columns |
| Create a filter view |
| Update a filter view |
| List all filter views in a sheet |
| Get a filter view by ID |
| Delete a filter view |
| Create a filter condition on a filter view |
| Update a filter condition |
| List all filter conditions of a filter view |
| Get a filter condition by column |
| Delete a filter condition |
下拉列表
| Shortcut | 说明 |
|---|---|
| 设置下拉列表( 写入的前置步骤) |
| 更新下拉列表选项 |
| 查询下拉列表配置 |
| 删除下拉列表 |
浮动图片
| Shortcut | 说明 |
|---|---|
| 上传本地图片素材,返回 (供 使用;>20MB 自动分片) |
| 创建浮动图片 |
| 更新浮动图片属性 |
| 获取浮动图片 |
| 查询所有浮动图片 |
| 删除浮动图片 |
浮动图片相关的读接口只返回元数据(含
),不包含图片字节。要读取图片内容,用 token 调float_image_token。lark-cli docs +media-preview --token "<float_image_token>" --output ./image.png
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
spreadsheet.sheet.float_images
— 创建浮动图片create
— 更新浮动图片patch
— 获取浮动图片get
— 查询所有浮动图片query
— 删除浮动图片delete
权限表
| 方法 | 所需 scope |
|---|---|
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |