notebooklm-mcp-cli
Programmatic access to Google NotebookLM — via command-line interface (CLI) or Model Context Protocol (MCP) server.
NotebookLM Web Importer
Importieren Sie Webseiten und YouTube-Videos mit einem Klick in NotebookLM. Vertraut von über 200.000 Nutzern.
Chrome-Erweiterung installierenMCP Guide
Complete reference for the NotebookLM MCP server — 35 tools for AI assistants.
Installation
# Install the package
uv tool install notebooklm-mcp-cli
# Add to Claude Code
claude mcp add --scope user notebooklm-mcp notebooklm-mcp
# Add to Gemini CLI
gemini mcp add --scope user notebooklm-mcp notebooklm-mcp
Authentication
Before using MCP tools, authenticate:
nlm login
Or use the standalone auth tool:
nlm login
Tool Reference
Notebooks (6 tools)
| Tool | Description | |------|-------------| | notebook_list | List all notebooks | | notebook_create | Create new notebook | | notebook_get | Get notebook details with sources | | notebook_describe | Get AI summary and suggested topics | | notebook_rename | Rename a notebook | | notebook_delete | Delete notebook (requires confirm=True) |
Sources (6 tools)
| Tool | Description | |------|-------------| | source_add | Unified - Add URL, text, file, or Drive source | | source_list_drive | List sources with Drive freshness status | | source_sync_drive | Sync stale Drive sources | | source_delete | Delete source (requires confirm=True) | | source_describe | Get AI summary with keywords | | source_get_content | Get raw text content |
source_add parameters:
source_add(
notebook_id="...",
source_type="url", # url | text | file | drive
url="https://...", # for source_type=url
text="...", # for source_type=text
title="...", # optional title
file_path="/path/to.pdf", # for source_type=file
document_id="...", # for source_type=drive
doc_type="doc", # doc | slides | sheets | pdf
wait=True, # wait for processing to complete
wait_timeout=120.0 # seconds to wait
)
Querying (2 tools)
| Tool | Description | |------|-------------| | notebook_query | Ask AI about sources in notebook | | chat_configure | Set chat goal and response length |
Studio Content (4 tools)
| Tool | Description | |------|-------------| | studio_create | Unified - Create any artifact type | | studio_status | Check generation progress | | studio_delete | Delete artifact (requires confirm=True) | | studio_revise | Revise slides in existing deck (requires confirm=True) |
studio_create artifact types:
audio- Podcast (formats: deep_dive, brief, critique, debate)video- Video overview (formats: explainer, brief)report- Text report (Briefing Doc, Study Guide, Blog Post)quiz- Multiple choice quizflashcards- Study flashcardsmind_map- Visual mind mapslide_deck- Presentation slidesinfographic- Visual infographicdata_table- Structured data table
Downloads (1 tool)
| Tool | Description | |------|-------------| | download_artifact | Unified - Download any artifact type |
download_artifact types: audio, video, report, mind_map, slide_deck, infographic, data_table, quiz, flashcards
Exports (1 tool)
| Tool | Description | |------|-------------| | export_artifact | Export to Google Docs/Sheets |
Research (3 tools)
| Tool | Description | |------|-------------| | research_start | Start web/Drive research | | research_status | Poll research progress | | research_import | Import discovered sources (timeout param for large notebooks) |
Notes (1 unified tool)
| Tool | Description | |------|-------------| | note | Unified - Manage notes (action: list, create, update, delete) |
note actions:
note(notebook_id, action="list") # List all notes
note(notebook_id, action="create", content="...", title="...")
note(notebook_id, action="update", note_id="...", content="...")
note(notebook_id, action="delete", note_id="...", confirm=True)
Sharing (3 tools)
| Tool | Description | |------|-------------| | notebook_share_status | Get sharing settings | | notebook_share_public | Enable/disable public link | | notebook_share_invite | Invite collaborator by email |
Auth (2 tools)
| Tool | Description | |------|-------------| | refresh_auth | Reload auth tokens | | save_auth_tokens | Save cookies (fallback method) |
Server (1 tool)
| Tool | Description | |------|-------------| | server_info | Get version and check for updates |
Batch & Cross-Notebook (2 tools)
| Tool | Description | |------|-------------| | batch | Unified — Batch operations across multiple notebooks (action: query, add_source, create, delete, studio) | | cross_notebook_query | Query multiple notebooks and get aggregated answers with per-notebook citations |
batch actions:
batch(action="query", query="What are the key findings?", notebook_names="AI Research, Dev Tools")
batch(action="add_source", source_url="https://...", tags="ai,research")
batch(action="create", titles="Project A, Project B, Project C")
batch(action="delete", notebook_names="Old Project", confirm=True)
batch(action="studio", artifact_type="audio", tags="research", confirm=True)
cross_notebook_query:
cross_notebook_query(query="Compare approaches", notebook_names="Notebook A, Notebook B")
cross_notebook_query(query="Summarize", tags="ai,research")
cross_notebook_query(query="Everything", all=True)
Pipelines (1 tool)
| Tool | Description | |------|-------------| | pipeline | Unified — List or run multi-step workflows (action: list, run) |
pipeline actions:
pipeline(action="list") # List available pipelines
pipeline(action="run", notebook_id="...", pipeline_name="ingest-and-podcast", input_url="https://...")
Built-in pipelines: ingest-and-podcast, research-and-report, multi-format
Tags & Smart Select (1 tool)
| Tool | Description | |------|-------------| | tag | Unified — Tag notebooks and find relevant ones (action: add, remove, list, select) |
tag actions:
tag(action="add", notebook_id="...", tags="ai,research,llm")
tag(action="remove", notebook_id="...", tags="ai")
tag(action="list") # List all tagged notebooks
tag(action="select", query="ai research") # Find notebooks by tag match
Example Workflows
Research → Podcast
1. research_start(query="AI trends 2026", mode="deep")
2. research_status(notebook_id, max_wait=300) # wait for completion
3. research_import(notebook_id, task_id, timeout=600) # optional: increase for large notebooks
4. studio_create(notebook_id, artifact_type="audio", confirm=True)
5. studio_status(notebook_id) # poll until complete
6. download_artifact(notebook_id, artifact_type="audio", output_path="podcast.mp3")
Add Sources with Wait
source_add(notebook_id, source_type="url", url="https://...", wait=True)
# Returns when source is fully processed and ready for queries
Generate Study Materials
studio_create(notebook_id, artifact_type="quiz", question_count=10, confirm=True)
studio_create(notebook_id, artifact_type="flashcards", difficulty="hard", confirm=True)
studio_create(notebook_id, artifact_type="report", report_format="Study Guide", confirm=True)
Tag, Batch & Cross-Notebook
# Tag notebooks for organization
tag(action="add", notebook_id="abc", tags="ai,research")
tag(action="add", notebook_id="def", tags="ai,product")
# Find relevant notebooks
tag(action="select", query="ai research")
# Query across tagged notebooks
cross_notebook_query(query="What are the main conclusions?", tags="ai")
# Batch generate podcasts for all tagged notebooks
batch(action="studio", artifact_type="audio", tags="ai", confirm=True)
Pipeline Automation
# List available pipelines
pipeline(action="list")
# Run a full ingest-and-podcast workflow
pipeline(action="run", notebook_id="abc", pipeline_name="ingest-and-podcast", input_url="https://example.com")
Configuration
MCP Server Options
| Flag | Description | Default | |------|-------------|---------| | --transport | Protocol (stdio, http, sse) | stdio | | --port | Port for HTTP/SSE | 8000 | | --debug | Enable verbose logging | false |
Environment Variables
| Variable | Description | |----------|-------------| | NOTEBOOKLM_MCP_TRANSPORT | Transport type | | NOTEBOOKLM_MCP_PORT | HTTP/SSE port | | NOTEBOOKLM_MCP_DEBUG | Enable debug logging | | NOTEBOOKLM_HL | Interface language and default artifact language (default: en) | | NOTEBOOKLM_QUERY_TIMEOUT | Query timeout (seconds) | | NOTEBOOKLM_BASE_URL | Override base URL for Enterprise/Workspace (default: https://notebooklm.google.com) |
Context Window Tips
This MCP has 35 tools which consume context. Best practices:
- Disable when not using: In Claude Code, use
@notebooklm-mcpto toggle - Use unified tools:
source_add,studio_create,download_artifacthandle multiple operations each - Poll wisely: Use
studio_statussparingly - artifacts take 1-5 minutes
IDE Configuration
The easiest way to configure any tool is with nlm setup:
nlm setup add claude-code # Claude Code
nlm setup add gemini # Gemini CLI
nlm setup add cursor # Cursor
nlm setup add windsurf # Windsurf
nlm setup add json # Any other tool (interactive JSON generator)
Manual configuration
Claude Code
claude mcp add --scope user notebooklm-mcp notebooklm-mcp
Cursor / VS Code
Add to ~/.cursor/mcp.json or ~/.vscode/mcp.json:
{
"mcpServers": {
"notebooklm-mcp": {
"command": "/path/to/notebooklm-mcp"
}
}
}
Gemini CLI
gemini mcp add --scope user notebooklm-mcp notebooklm-mcp
Verwandte Server
Hyperweb
A server for interacting with the Hyperweb platform and its tools using AI agents.
DaVinci Resolve MCP
An MCP server integration for the DaVinci Resolve video editing software.
Scenext MCP Server
Integrates with the Scenext AI platform to generate educational videos on various topics.
Browser Use
A simple, self-contained notes system with resources, tools, and prompts.
GSuite
Interact with Google products, including Gmail and Calendar.
n8n-mcp
A simple note storage system with tools to add and summarize notes using a custom note:// URI scheme.
Geekbot MCP
An MCP server that integrates Geekbot data and tools with AI models.
Tmux
Interact with your Tmux sessions, windows and pane, execute commands in tmux panes and retrieve result.
Mealie
Interact with your Mealie recipe database to manage and find recipes.
TrackMage
Shipment tracking api and logistics management capabilities through the TrackMage API