Notion CLI Agent
Notion CLI with AI agent support. Smart queries, Obsidian sync, batch ops, backups, validation and more.
Ask AI about Notion CLI Agent
Powered by Claude Β· Grounded in docs
I know everything about Notion CLI Agent. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
notion-cli-agent
The most powerful command-line interface for Notion β built for AI agents first, humans too.
notion-cli-agent is designed to be used by AI agents that need to read and write Notion workspaces β natural language queries, batch operations, --llm output mode, workspace introspection, and more. Works great for humans too.
π€ For AI Agents
Quick start
npm install -g notion-cli-agent
export NOTION_TOKEN="ntn_your_token_here"
# Full quick reference (read this first)
notion quickstart
Agent Skills (recommended)
This repo ships AgentSkills-compatible skill files in the skills/ directory. Skills use progressive disclosure: the core SKILL.md is small enough to live in your agent's context window, and detailed reference files (filters.md, batch-patterns.md, workflows.md) are loaded on demand.
skills/
βββ notion-onboarding/ β run first: maps your workspace to a state file
βββ notion-cli-agent/ β core CLI skill + references
Recommended setup for agents:
- Install skills in your agent framework (see
skills/README.md) - Run the
notion-onboardingskill once β it discovers your databases (tasks, projects, OKRs, home page) and saves them to~/.config/notion/workspace.json - All subsequent tasks use the mapped IDs automatically β no more looking up database IDs
Why a CLI over the Notion MCP/API?
--llmmode β compact, structured output optimized for agent consumptionnotion findβ natural language β Notion filters in one commandnotion batchβ multiple operations in a single shell call (minimize tool calls)notion ai promptβ generates a database-specific prompt for the agentnotion inspect contextβ full schema + examples + command reference in one shot- No rate-limit boilerplate, no SDK setup, shell-composable
β¨ Features
Core Operations
- Search β Find pages and databases across your workspace
- Pages β Create, read, update, archive pages with full property support
- Databases β Query with filters, create schemas, manage entries
- Blocks β Add and manage page content (paragraphs, headings, lists, code, etc.)
- Comments β Read and create comments on pages
- Users β List workspace users and integrations
π€ AI Agent Features
- Smart Queries β Natural language queries translated to Notion filters
- Batch Operations β Execute multiple operations in one command
- Agent Prompts β Generate optimal prompts for AI agents to work with databases
- Summarize β Get concise page summaries
- Extract β Pull structured data from page content
π Obsidian Integration
- Export to Obsidian β Pages and databases with YAML frontmatter
- Import from Obsidian β Import vault notes to Notion
- CSV & Markdown import β Bulk import from files
π Analytics & Validation
- Statistics β Database metrics, breakdowns by property
- Timeline β Activity visualization over time
- Health Check β Database integrity scoring
- Validation β Find missing fields, overdue items, stale entries
π Advanced Features
- Workspace Sync β Cache databases locally, use names instead of UUIDs everywhere
- Templates β Save and reuse page structures
- Backup β Full database backup to JSON/Markdown
- Duplicate β Clone pages and entire databases
- Relations β Manage links, find backlinks, visualize graphs
- Bulk Operations β Update or archive hundreds of entries at once
π¦ Installation
From npm (recommended)
npm install -g notion-cli-agent
From source
# Clone the repository
git clone https://github.com/Balneario-de-Cofrentes/notion-cli-agent.git
cd notion-cli-agent
# Install dependencies
pnpm install
# Build
pnpm build
# Link globally
pnpm link --global
Requirements
- Node.js 20+
- A Notion integration token (create one here)
βοΈ Configuration
1. Get your API token
- Go to notion.so/my-integrations
- Click "New integration"
- Give it a name and select capabilities
- Copy the token (starts with
ntn_orsecret_)
2. Set the token
# Option 1: Environment variable (recommended)
export NOTION_TOKEN="ntn_your_token_here"
# Option 2: Pass directly
notion --token "ntn_xxx" search "query"
3. Share content with your integration
Important: Your integration can only access pages explicitly shared with it.
- Open any page or database in Notion
- Click "..." menu β "Connect to" β Select your integration
π Workspace Sync
Sync your workspace to use database names instead of UUIDs:
# Cache all accessible databases locally
notion sync
# List cached databases
notion list
notion list --json # For scripts
notion list --ids-only # One ID per line
# Now use names anywhere you'd use a database UUID
notion db query "Tasks" --limit 5
notion find "Tasks" "overdue assigned to me"
notion validate health "Projects"
notion stats overview "OKRs"
All database commands accept both UUIDs and names. Name resolution uses case-insensitive matching with substring fallback. If a name is ambiguous, the CLI shows candidates and asks you to be more specific.
π Usage Guide
Basic Commands
# Search across workspace
notion search "project plan"
notion search "meeting" --type page
notion search "" --type database # List all databases
# Exact lookup in a known database (deterministic)
notion db query <db_id> --title "Known Page" --json
# Filtered search (best-effort β Notion search is fuzzy)
notion search "keyword" --db <db_id> --exact --first --json
notion search "task" --db <db_id> # Filter by parent database
# Get page info
notion page get <page_id>
notion page get <page_id> --content # Include blocks
# Create page in database
notion page create --parent <db_id> --title "New Task"
notion page create --parent <db_id> --title "Bug Fix" \
--prop "Status=Todo" \
--prop "Priority=High"
notion page create --parent <db_id> --title "Meeting Notes" --icon π
# Update page
notion page update <page_id> --prop "Status:status=Done"
notion page update <page_id> --title "New Title"
notion page update <page_id> --icon π
notion page update <page_id> --clear-prop "Assignee" # Type-aware clear
# Archive page
notion page archive <page_id>
Output Formats
# Export database as CSV
notion db query <db_id> --csv > tasks.csv
# Tab-separated (paste into spreadsheets)
notion db query <db_id> --tsv | pbcopy
# Just IDs for piping into other commands
notion db query <db_id> --filter "Status=Done" --ids-only | \
xargs -I {} notion page archive {}
# Count search results
notion search "bugs" --ids-only | wc -l
| Flag | Commands | Description |
|---|---|---|
--json / -j | all | Raw JSON |
--llm | most | Compact agent-friendly output |
--csv | db query, find | CSV with headers |
--tsv | db query, find | Tab-separated |
--ids-only | db query, search, find | One ID per line |
π Page Content (read/write/edit)
Read, write, and surgically edit page content as Markdown.
# Read page content as Markdown (uses native Notion markdown API)
notion page read <page_id>
notion page read <page_id> --blocks # Legacy: fetch blocks and convert client-side
notion page read <page_id> --json # Raw block JSON output
notion page read <page_id> -o page.md # Write to file
# Write Markdown content into a page
notion page write <page_id> -f content.md
echo "# Hello" | notion page write <page_id>
notion page write <page_id> -f doc.md --replace # Replace all content (destructive)
# Surgical block-level editing
notion page edit <page_id> --at 3 --delete 2 # Delete 2 blocks at index 3
notion page edit <page_id> --at 5 --markdown "New paragraph" # Insert at index 5
notion page edit <page_id> --at 0 --delete 1 --file new.md # Replace first block
notion page edit <page_id> --dry-run --at 3 --delete 1 # Preview without changes
π€ AI Agent Features
Smart Queries with find
Translate natural language into Notion filters:
# Find overdue tasks
notion find "overdue tasks" -d <db_id>
# Find unassigned items in progress
notion find "in progress unassigned" -d <db_id>
# Find high priority pending items
notion find "urgent pending" -d <db_id>
# See what filter was generated
notion find "tareas vencidas" -d <db_id> --explain
Supported patterns:
- Status:
done,in progress,todo,pending,hecho,en marcha - Assignment:
unassigned,sin asignar - Dates:
overdue,vencidas,today,this week - Priority:
urgent,high priority,importante
Batch Operations
Execute multiple operations in one command β perfect for AI agents to minimize tool calls:
# Preview what would happen
notion batch --dry-run --data '[
{"op": "get", "type": "page", "id": "abc123"},
{"op": "create", "type": "page", "parent": "db_id", "data": {...}},
{"op": "update", "type": "page", "id": "xyz789", "data": {...}}
]'
# Execute with LLM-friendly output
notion batch --llm --data '[...]'
# Read from file
notion batch -f operations.json
Supported operations:
| Op | Types | Description |
|---|---|---|
get | page, database, block | Retrieve by ID |
create | page, database | Create new |
update | page, database, block | Modify |
delete | page, block | Archive/delete |
query | database | Query with filters |
append | block | Add children |
Generate Agent Prompts
Create optimal prompts for AI agents to work with a specific database:
notion ai prompt <database_id>
Output includes:
- Database schema with all properties
- Valid values for select/status fields (exact spelling matters!)
- Example entries
- Common operations with correct syntax
- Warnings about property naming (e.g., "Title is called 'TΓtulo', not 'Name'")
Summarize Pages
Get concise summaries for quick understanding:
notion ai summarize <page_id>
# Output:
# Project Plan Q1
# Last edited: 2 days ago
# Blocks: 45
# Properties:
# - Status: In Progress
# - Owner: Juan
# Sections:
# - Overview
# - Timeline
# - Resources
# Todos: 8/12 completed
Extract Structured Data
Pull specific data points from page content:
notion ai extract <page_id> --schema "email,phone,company,date"
# Output:
{
"email": "contact@example.com",
"phone": "+34 612 345 678",
"company": "Acme Corp",
"date": "2024-03-15"
}
Command Suggestions
Get command suggestions based on natural language:
notion ai suggest <db_id> "quiero ver las tareas completadas esta semana"
# Outputs:
# notion find "hecho" -d <db_id>
# notion db query <db_id> --filter-prop "Status" --filter-value "Hecho" --filter-prop-type status
π Obsidian Integration
Export to Obsidian
Export a single page:
notion export page <page_id> --obsidian -o my-note.md
Export entire database to vault:
notion export db <database_id> --vault ~/obsidian-vault --folder notion-tasks
With full page content:
notion export db <db_id> --vault ~/vault --content
Exported files include:
---
notion_id: "abc123..."
notion_url: "https://notion.so/..."
created: 2024-01-15
updated: 2024-02-01
status: "In Progress"
priority: "High"
tags:
- "project"
- "q1"
---
# Page Title
Content here...
Import from Obsidian
Import vault to database:
notion import obsidian ~/my-vault --to <database_id>
notion import obsidian ~/my-vault --to <db_id> --folder specific-folder
notion import obsidian ~/my-vault --to <db_id> --content # Include page content
Import CSV:
notion import csv data.csv --to <database_id>
notion import csv tasks.csv --to <db_id> --title-column "Task Name"
Import Markdown file:
notion import markdown document.md --to <page_id>
notion import markdown doc.md --to <page_id> --replace # Replace existing content
π Database Analytics
Statistics Overview
notion stats overview <database_id>
# Output:
# π Database: Tasks
# Total entries: 342
#
# Status:
# Done 124 (36%) ββββββββ
# In Progress 89 (26%) ββββββ
# Todo 78 (23%) βββββ
# Blocked 51 (15%) βββ
#
# Priority:
# High 45 (13%) βββ
# Medium 187 (55%) βββββββββββ
# Low 110 (32%) βββββββ
Activity Timeline
notion stats timeline <database_id> --days 14
# 2024-02-01 (Thu) 12 ββββββββββββ
# 2024-01-31 (Wed) 8 ββββββββ
# 2024-01-30 (Tue) 15 βββββββββββββββ
# ...
β Validation & Health
Full Validation
notion validate check <database_id> \
--required "Assignee,Deadline" \
--check-dates \
--check-stale 30 \
--fix
# Output:
# β οΈ MISSING REQUIRED (23)
# - Task ABC: Missing required property: Assignee
# - Task XYZ: Missing required property: Deadline
# Fix: notion page update <id> --prop "Assignee=..."
#
# β οΈ OVERDUE (8)
# - Old task: Overdue: deadline was 2024-01-15
#
# βΉοΈ STALE (5)
# - Stuck item: Not updated in 45 days (status: In Progress)
#
# π Health Score: 72/100
Quick Lint
notion validate lint <database_id>
# β
Empty titles: OK
# β οΈ "In Progress" for >30 days: 5 found
# Total issues: 5
Health Report
notion validate health <database_id>
# π Health Report: Tasks
# ββββββββββββββββββββββββββββββββββββββββ
# Health Score: 78/100 π‘
# ββββββββββββββββββββββββββββββββββββββββ
#
# π Activity (last 7 days): 34/100 entries (34%)
# β
Completion rate: 65%
# π Average fill rate: 82%
#
# Property fill rates:
# β
Title ββββββββββ 100%
# β
Status ββββββββββ 100%
# β οΈ Assignee ββββββββββ 77%
# β Tags ββββββββββ 15%
πΎ Backup & Restore
Full Database Backup
# Backup to JSON
notion backup <database_id> -o ./backups/tasks
# Backup to Markdown
notion backup <db_id> -o ./backups --format markdown
# Include page content
notion backup <db_id> -o ./backups --content
# Incremental backup (only changed entries)
notion backup <db_id> -o ./backups --incremental
Output structure:
backups/
βββ schema.json # Database schema
βββ index.json # Entry index
βββ .backup-meta.json # Backup metadata
βββ pages/
βββ Task_One_abc123.json
βββ Task_Two_def456.json
βββ ...
π§Ή Dedup β Find & Clean Duplicates
# Find duplicate pages by title
notion dedup <db_id>
# Include near-duplicates (strips copy/draft suffixes)
notion dedup <db_id> --fuzzy
# Archive duplicates, keep the page with most content
notion dedup <db_id> --fix --strategy keep-largest --yes
# Keep newest or oldest
notion dedup <db_id> --fix --strategy keep-newest --yes
notion dedup <db_id> --fix --strategy keep-oldest --yes
# Preview first (default when --fix without --yes)
notion dedup <db_id> --fix --strategy keep-largest
π Relations & Backlinks
Find Backlinks
Discover what pages link to a specific page:
notion relations backlinks <page_id>
# π Direct Relations:
# Project Alpha
# ββ via property: Related Tasks
#
# Sprint 23
# ββ via property: Tasks
#
# π Potential Mentions:
# Meeting Notes Jan 15
# Weekly Report
Link/Unlink Pages
# Create relation
notion relations link <source_id> <target_id> --property "Related"
# Bidirectional linking
notion relations link <page1> <page2> --property "Related" --bidirectional
# Remove relation
notion relations unlink <source_id> <target_id> --property "Related"
Visualize Relationship Graph
# Text format
notion relations graph <page_id> --depth 2
# DOT format (for Graphviz)
notion relations graph <page_id> --format dot > graph.dot
dot -Tpng graph.dot -o graph.png
# JSON format
notion relations graph <page_id> --format json
π Templates
Save a Page as Template
notion template save <page_id> --name "weekly-report" --description "Weekly team report"
List Templates
notion template list
# π weekly-report
# Blocks: 15
# Description: Weekly team report
#
# π meeting-notes
# Blocks: 8
Use Template
notion template use "weekly-report" --parent <db_id> --title "Report Week 5"
Manage Templates
notion template show "weekly-report" # View details
notion template delete "weekly-report" # Remove
π Bulk Operations
Bulk Update
Update multiple entries at once:
# Preview first
notion bulk update <db_id> --where "Status=Todo" --set "Status=In Progress" --dry-run
# Execute
notion bulk update <db_id> --where "Status=Todo" --set "Status=In Progress" --yes
Bulk Archive
Archive entries matching a condition:
# Archive completed items older than 2024
notion bulk archive <db_id> --where "Status=Done" --dry-run
notion bulk archive <db_id> --where "Status=Done" --yes
Where clause syntax:
- Equals:
Property=Value - Multiple conditions:
Status=Done,Priority=Low
π Workspace Introspection
List Accessible Databases
notion inspect workspace
notion inspect ws --compact # Just names and IDs
Get Database Schema
notion inspect schema <database_id>
notion inspect schema <db_id> --llm # Optimized for AI consumption
Generate Context for AI
notion inspect context <database_id>
# Outputs comprehensive context including:
# - Schema with all properties and valid values
# - Example entries
# - Quick command reference
π Raw API Access
For operations not covered by other commands:
# GET request
notion api GET "pages/<page_id>"
# POST with body
notion api POST "search" --data '{"query": "test"}'
# With query parameters
notion api GET "users" --query "page_size=5"
π Property Formats
When setting properties with --prop, the CLI auto-detects types:
| Value Format | Detected Type | Example |
|---|---|---|
| Plain text | select | --prop "Status=Done" |
true/false | checkbox | --prop "Active=true" |
| Numbers | number | --prop "Count=42" |
YYYY-MM-DD | date | --prop "Due=2024-12-31" |
| URL | url | --prop "Link=https://..." |
--prop "Contact=a@b.com" | ||
| Comma-separated | multi_select | --prop "Tags=bug,urgent" |
Type hints β Force a specific property type with Key:type=Value:
# Status properties (vs auto-detected select)
notion page update <id> --prop "Status:status=Done"
# Rich text instead of select
notion page update <id> --prop "Notes:rich_text=Some notes"
# People by user ID
notion page update <id> --prop "Assignee:people=user-id-here"
For database queries with non-select properties:
notion db query <db_id> \
--filter-prop "Status" \
--filter-type equals \
--filter-value "Done" \
--filter-prop-type status # Required for status type
π MCP Server Mode
Run as an MCP tool server for agent frameworks (Claude Code, Cursor, VS Code):
notion --mcp
Configure in Claude Code (settings.json):
{
"mcpServers": {
"notion": {
"command": "notion",
"args": ["--mcp"],
"env": { "NOTION_TOKEN": "ntn_your_token" }
}
}
}
Exposes 14 tools: search, page_get, page_create, page_update, db_query, db_schema, block_children, block_append, find, batch, inspect_workspace, comment_create, validate_health, dedup.
π― Command Reference
| Category | Commands |
|---|---|
| Search | search |
| Pages | page get, page create, page update, page archive, page read, page write, page edit, page property |
| Databases | db get, db query, db create, db update |
| Blocks | block get, block list, block append, block update, block delete |
| Comments | comment list, comment create, comment get |
| Users | user me, user list, user get |
| Export | export page, export db |
| Import | import obsidian, import csv, import markdown |
| AI | ai summarize, ai extract, ai prompt, ai suggest |
| Find | find |
| Bulk | bulk update, bulk archive |
| Validate | validate check, validate lint, validate health |
| Stats | stats overview, stats timeline |
| Backup | backup |
| Templates | template list, template save, template use, template show, template delete |
| Duplicate | duplicate page, duplicate schema, duplicate db |
| Relations | relations backlinks, relations link, relations unlink, relations graph |
| Inspect | inspect workspace, inspect schema, inspect context |
| Dedup | dedup |
| Batch | batch |
| Quickstart | quickstart |
| API | api |
π¦ Agent Skills
The skills/ directory contains AgentSkills-compatible packages for use with OpenClaw, Claude Code, Cursor, and other agent frameworks.
Structure
skills/
βββ README.md # Installation & overview
βββ notion-onboarding/
β βββ SKILL.md # Workspace discovery workflow
β βββ references/
β βββ state-schema.md # ~/.config/notion/workspace.json schema
βββ notion-cli-agent/
βββ SKILL.md # Core CLI usage
βββ references/
βββ filters.md # Property types Γ filter operators
βββ batch-patterns.md # Multi-op batch patterns
βββ workflows.md # Agent workflow recipes
Progressive disclosure
Skills load in three layers to keep context usage efficient:
| Layer | Content | When loaded |
|---|---|---|
| Metadata | name + description | Always β triggers the skill |
| Core | SKILL.md body | When skill activates |
| Reference | references/*.md | On demand, as needed |
The main SKILL.md for each skill is kept under 150 lines. Deep reference material lives in separate files that the agent reads only when that topic comes up.
Installation
# OpenClaw
cp -r skills/notion-cli-agent ~/.local/share/openclaw/skills/
cp -r skills/notion-onboarding ~/.local/share/openclaw/skills/
# See skills/README.md for other frameworks
π€ Contributing
Contributions are welcome! Please open an issue first to discuss what you would like to change.
π License
MIT Β© Balneario de Cofrentes - The largest longevity clinic in the world.
π Acknowledgments
Built with:
- Commander.js β CLI framework
- Notion API β Official Notion API
