NotionAPI技能Skill notion

这是一个用于自动化操作 Notion 工作空间的技能。它提供了通过 Notion API 进行编程式访问的能力,允许用户创建、读取、更新和删除 Notion 中的页面、数据库(数据源)以及内容块。核心功能包括数据源查询、页面管理、内容编辑和属性设置。适用于个人知识管理自动化、团队协作工具集成、数据同步和内容管理系统构建等场景。关键词:Notion API,自动化,页面管理,数据库操作,内容管理,工作流集成,REST API,知识管理,团队协作。

后端开发 0 次安装 4 次浏览 更新于 2/24/2026

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 来创建/读取/更新页面、数据源(数据库)和块。

设置

  1. https://notion.so/my-integrations 创建一个集成
  2. 复制 API 密钥(以 ntn_secret_ 开头)
  3. 存储它:
mkdir -p ~/.config/notion
echo "ntn_your_key_here" > ~/.config/notion/api_key
  1. 将目标页面/数据库与您的集成共享(点击“…” → “连接到” → 您的集成名称)

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_iddata_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