名称: notion
描述: 用于创建和管理页面、数据库(数据源)及内容块的 Notion API。
主页: https://developers.notion.com
元数据: {"clawdbot":{"emoji":"📝"}}
使用 Notion API 来创建、读取、更新页面、数据源(数据库)和内容块。
ntn_ 或 secret_ 开头)。bash
mkdir -p ~/.config/notion
echo "ntn_your_key_here" > ~/.config/notion/api_key所有请求都需要以下信息:
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": "page title"}'
获取页面:
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": "New Item"}}]},
"Status": {"select": {"name": "Todo"}}
}
}'
查询数据源(数据库):
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": "Active"}},
"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": "My Database"}}],
"properties": {
"Name": {"title": {}},
"Status": {"select": {"options": [{"name": "Todo"}, {"name": "Done"}]}},
"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": "Done"}}}}'
向页面添加内容块:
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": "Hello"}}]}}
]
}'
数据库条目常用的属性格式:
- 标题: {"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"}]}
/data_sources/ 端点进行查询和检索。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。GET /v1/data_sources/{data_source_id}。is_inline: true 可将其嵌入到页面中。