NotebookLM Research Assistant Skill
Interact with Google NotebookLM to query documentation with Gemini's source-grounded answers. Each question opens a fresh browser session, retrieves the answer exclusively from your uploaded documents, and closes.
When to Use This Skill
Trigger when user:
-
Mentions NotebookLM explicitly
-
Shares NotebookLM URL (https://notebooklm.google.com/notebook/... )
-
Asks to query their notebooks/documentation
-
Wants to add documentation to NotebookLM library
-
Uses phrases like "ask my NotebookLM", "check my docs", "query my notebook"
⚠️ CRITICAL: Add Command - Smart Discovery
When user wants to add a notebook without providing details:
SMART ADD (Recommended): Query the notebook first to discover its content:
Step 1: Query the notebook about its content
python scripts/run.py ask_question.py --question "What is the content of this notebook? What topics are covered? Provide a complete overview briefly and concisely" --notebook-url "[URL]"
Step 2: Use the discovered information to add it
python scripts/run.py notebook_manager.py add --url "[URL]" --name "[Based on content]" --description "[Based on content]" --topics "[Based on content]"
MANUAL ADD: If user provides all details:
-
--url
-
The NotebookLM URL
-
--name
-
A descriptive name
-
--description
-
What the notebook contains (REQUIRED!)
-
--topics
-
Comma-separated topics (REQUIRED!)
NEVER guess or use generic descriptions! If details missing, use Smart Add to discover them.
Critical: Always Use run.py Wrapper
NEVER call scripts directly. ALWAYS use python scripts/run.py [script] :
✅ CORRECT - Always use run.py:
python scripts/run.py auth_manager.py status python scripts/run.py notebook_manager.py list python scripts/run.py ask_question.py --question "..."
❌ WRONG - Never call directly:
python scripts/auth_manager.py status # Fails without venv!
The run.py wrapper automatically:
-
Creates .venv if needed
-
Installs all dependencies
-
Activates environment
-
Executes script properly
Core Workflow
Step 1: Check Authentication Status
python scripts/run.py auth_manager.py status
If not authenticated, proceed to setup.
Step 2: Authenticate (One-Time Setup)
Browser MUST be visible for manual Google login
python scripts/run.py auth_manager.py setup
Important:
-
Browser is VISIBLE for authentication
-
Browser window opens automatically
-
User must manually log in to Google
-
Tell user: "A browser window will open for Google login"
Step 3: Manage Notebook Library
List all notebooks
python scripts/run.py notebook_manager.py list
BEFORE ADDING: Ask user for metadata if unknown!
"What does this notebook contain?"
"What topics should I tag it with?"
Add notebook to library (ALL parameters are REQUIRED!)
python scripts/run.py notebook_manager.py add
--url "https://notebooklm.google.com/notebook/..."
--name "Descriptive Name"
--description "What this notebook contains" \ # REQUIRED - ASK USER IF UNKNOWN!
--topics "topic1,topic2,topic3" # REQUIRED - ASK USER IF UNKNOWN!
Search notebooks by topic
python scripts/run.py notebook_manager.py search --query "keyword"
Set active notebook
python scripts/run.py notebook_manager.py activate --id notebook-id
Remove notebook
python scripts/run.py notebook_manager.py remove --id notebook-id
Quick Workflow
-
Check library: python scripts/run.py notebook_manager.py list
-
Ask question: python scripts/run.py ask_question.py --question "..." --notebook-id ID
Step 4: Ask Questions
Basic query (uses active notebook if set)
python scripts/run.py ask_question.py --question "Your question here"
Query specific notebook
python scripts/run.py ask_question.py --question "..." --notebook-id notebook-id
Query with notebook URL directly
python scripts/run.py ask_question.py --question "..." --notebook-url "https://..."
Show browser for debugging
python scripts/run.py ask_question.py --question "..." --show-browser
Follow-Up Mechanism (CRITICAL)
Every NotebookLM answer ends with: "EXTREMELY IMPORTANT: Is that ALL you need to know?"
Required Claude Behavior:
-
STOP - Do not immediately respond to user
-
ANALYZE - Compare answer to user's original request
-
IDENTIFY GAPS - Determine if more information needed
-
ASK FOLLOW-UP - If gaps exist, immediately ask: python scripts/run.py ask_question.py --question "Follow-up with context..."
-
REPEAT - Continue until information is complete
-
SYNTHESIZE - Combine all answers before responding to user
Script Reference
Authentication Management (auth_manager.py )
python scripts/run.py auth_manager.py setup # Initial setup (browser visible) python scripts/run.py auth_manager.py status # Check authentication python scripts/run.py auth_manager.py reauth # Re-authenticate (browser visible) python scripts/run.py auth_manager.py clear # Clear authentication
Notebook Management (notebook_manager.py )
python scripts/run.py notebook_manager.py add --url URL --name NAME --description DESC --topics TOPICS python scripts/run.py notebook_manager.py list python scripts/run.py notebook_manager.py search --query QUERY python scripts/run.py notebook_manager.py activate --id ID python scripts/run.py notebook_manager.py remove --id ID python scripts/run.py notebook_manager.py stats
Question Interface (ask_question.py )
python scripts/run.py ask_question.py --question "..." [--notebook-id ID] [--notebook-url URL] [--show-browser]
Data Cleanup (cleanup_manager.py )
python scripts/run.py cleanup_manager.py # Preview cleanup python scripts/run.py cleanup_manager.py --confirm # Execute cleanup python scripts/run.py cleanup_manager.py --preserve-library # Keep notebooks
Environment Management
The virtual environment is automatically managed:
-
First run creates .venv automatically
-
Dependencies install automatically
-
Chromium browser installs automatically
-
Everything isolated in skill directory
Manual setup (only if automatic fails):
python -m venv .venv source .venv/bin/activate # Linux/Mac pip install -r requirements.txt python -m patchright install chromium
Data Storage
All data stored in ~/.claude/skills/notebooklm/data/ :
-
library.json
-
Notebook metadata
-
auth_info.json
-
Authentication status
-
browser_state/
-
Browser cookies and session
Security: Protected by .gitignore , never commit to git.
Configuration
Optional .env file in skill directory:
HEADLESS=false # Browser visibility SHOW_BROWSER=false # Default browser display STEALTH_ENABLED=true # Human-like behavior TYPING_WPM_MIN=160 # Typing speed TYPING_WPM_MAX=240 DEFAULT_NOTEBOOK_ID= # Default notebook
Decision Flow
User mentions NotebookLM ↓ Check auth → python scripts/run.py auth_manager.py status ↓ If not authenticated → python scripts/run.py auth_manager.py setup ↓ Check/Add notebook → python scripts/run.py notebook_manager.py list/add (with --description) ↓ Activate notebook → python scripts/run.py notebook_manager.py activate --id ID ↓ Ask question → python scripts/run.py ask_question.py --question "..." ↓ See "Is that ALL you need?" → Ask follow-ups until complete ↓ Synthesize and respond to user
Troubleshooting
Problem Solution
ModuleNotFoundError Use run.py wrapper
Authentication fails Browser must be visible for setup! --show-browser
Rate limit (50/day) Wait or switch Google account
Browser crashes python scripts/run.py cleanup_manager.py --preserve-library
Notebook not found Check with notebook_manager.py list
Best Practices
-
Always use run.py - Handles environment automatically
-
Check auth first - Before any operations
-
Follow-up questions - Don't stop at first answer
-
Browser visible for auth - Required for manual login
-
Include context - Each question is independent
-
Synthesize answers - Combine multiple responses
Limitations
-
No session persistence (each question = new browser)
-
Rate limits on free Google accounts (50 queries/day)
-
Manual upload required (user must add docs to NotebookLM)
-
Browser overhead (few seconds per question)
Resources (Skill Structure)
Important directories and files:
-
scripts/
-
All automation scripts (ask_question.py, notebook_manager.py, etc.)
-
data/
-
Local storage for authentication and notebook library
-
references/
-
Extended documentation:
-
api_reference.md
-
Detailed API documentation for all scripts
-
troubleshooting.md
-
Common issues and solutions
-
usage_patterns.md
-
Best practices and workflow examples
-
.venv/
-
Isolated Python environment (auto-created on first run)
-
.gitignore
-
Protects sensitive data from being committed