name: notion description: Notion API 用于创建和管理页面、数据库和块。 homepage: https://developers.notion.com metadata: { “openclaw”: { “emoji”: “📝”, “requires”: { “env”: [“NOTION_API_KEY”] }, “primaryEnv”: “NOTION_API_KEY” }, }
notion
使用 Notion API 来创建/读取/更新页面、数据源(数据库)和块。
设置
- 在 https://notion.so/my-integrations 创建一个集成
- 复制 API 密钥(以
ntn_或secret_开头) - 存储它:
mkdir -p ~/.config/notion
echo "ntn_your_key_here" > ~/.config/notion/api_key
- 将目标页面/数据库与您的集成共享(点击“…” → “连接到” → 您的集成名称)
API 基础
所有请求都需要:
NOTION_KEY=$(cat ~/.config/notion/api_key)
curl -X GET "https://api.notion.com/v1/..." \
-H "Authorization: Bearer $NOTION_KEY" \
-H "Notion-Version: 2025-09-03" \
-H "Content-Type: application/json"
注意:
Notion-Version请求头是必需的。此技能使用2025-09-03(最新版本)。在此版本中,API 中将数据库称为“数据源”。
常见操作
搜索页面和数据源:
curl -X POST "https://api.notion.com/v1/search" \
-H "Authorization: Bearer $NOTION_KEY" \
-H "Notion-Version: 2025-09-03" \
-H "Content-Type: application/json" \
-d '{"query": "页面标题"}'
获取页面:
curl "https://api.notion.com/v1/pages/{page_id}" \
-H "Authorization: Bearer $NOTION_KEY" \
-H "Notion-Version: 2025-09-03"
获取页面内容(块):
curl "https://api.notion.com/v1/blocks/{page_id}/children" \
-H "Authorization: Bearer $NOTION_KEY" \
-H "Notion-Version: 2025-09-03"
在数据源中创建页面:
curl -X POST "https://api.notion.com/v1/pages" \
-H "Authorization: Bearer $NOTION_KEY" \
-H "Notion-Version: 2025-09-03" \
-H "Content-Type: application/json" \
-d '{
"parent": {"database_id": "xxx"},
"properties": {
"Name": {"title": [{"text": {"content": "新项目"}}]},
"Status": {"select": {"name": "待办"}}
}
}'
查询数据源(数据库):
curl -X POST "https://api.notion.com/v1/data_sources/{data_source_id}/query" \
-H "Authorization: Bearer $NOTION_KEY" \
-H "Notion-Version: 2025-09-03" \
-H "Content-Type: application/json" \
-d '{
"filter": {"property": "Status", "select": {"equals": "活跃"}},
"sorts": [{"property": "Date", "direction": "descending"}]
}'
创建数据源(数据库):
curl -X POST "https://api.notion.com/v1/data_sources" \
-H "Authorization: Bearer $NOTION_KEY" \
-H "Notion-Version: 2025-09-03" \
-H "Content-Type: application/json" \
-d '{
"parent": {"page_id": "xxx"},
"title": [{"text": {"content": "我的数据库"}}],
"properties": {
"Name": {"title": {}},
"Status": {"select": {"options": [{"name": "待办"}, {"name": "完成"}]}},
"Date": {"date": {}}
}
}'
更新页面属性:
curl -X PATCH "https://api.notion.com/v1/pages/{page_id}" \
-H "Authorization: Bearer $NOTION_KEY" \
-H "Notion-Version: 2025-09-03" \
-H "Content-Type: application/json" \
-d '{"properties": {"Status": {"select": {"name": "完成"}}}}'
向页面添加块:
curl -X PATCH "https://api.notion.com/v1/blocks/{page_id}/children" \
-H "Authorization: Bearer $NOTION_KEY" \
-H "Notion-Version: 2025-09-03" \
-H "Content-Type: application/json" \
-d '{
"children": [
{"object": "block", "type": "paragraph", "paragraph": {"rich_text": [{"text": {"content": "你好"}}]}}
]
}'
属性类型
数据库项目的常见属性格式:
- 标题:
{"title": [{"text": {"content": "..."}}]} - 富文本:
{"rich_text": [{"text": {"content": "..."}}]} - 单选:
{"select": {"name": "选项"}} - 多选:
{"multi_select": [{"name": "A"}, {"name": "B"}]} - 日期:
{"date": {"start": "2024-01-15", "end": "2024-01-16"}} - 复选框:
{"checkbox": true} - 数字:
{"number": 42} - URL:
{"url": "https://..."} - 邮箱:
{"email": "a@b.com"} - 关联:
{"relation": [{"id": "page_id"}]}
2025-09-03 版本的主要区别
- 数据库 → 数据源: 使用
/data_sources/端点进行查询和检索 - 两个 ID: 现在每个数据库都有
database_id和data_source_id- 创建页面时使用
database_id(parent: {"database_id": "..."}) - 查询时使用
data_source_id(POST /v1/data_sources/{id}/query)
- 创建页面时使用
- 搜索结果: 数据库以
"object": "data_source"的形式返回,并带有其data_source_id - 响应中的父级: 页面显示
parent.data_source_id以及parent.database_id - 查找 data_source_id: 搜索数据库,或调用
GET /v1/data_sources/{data_source_id}
注意事项
- 页面/数据库 ID 是 UUID(带或不带短横线)
- API 无法设置数据库视图过滤器——这仅限于 UI 操作
- 速率限制:平均约每秒 3 个请求
- 在页面中嵌入数据源时,创建数据源时使用
is_inline: true