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
.venvif 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
Step 5: Cross-Notebook Analysis (Multiple Notebooks)
When user wants to query multiple notebooks with the same question (e.g., for project hierarchies with sub-projects + overall project):
# Query ALL notebooks in library with the same question python scripts/run.py ask_multiple.py --question "What are the main risks?" --all-notebooks # Query SPECIFIC notebooks by ID python scripts/run.py ask_multiple.py --question "GPU status?" --notebook-ids "id1,id2,id3" # Show browser for debugging python scripts/run.py ask_multiple.py --question "..." --all-notebooks --show-browser
When to use Cross-Notebook Analysis:
- •User has project hierarchy (sub-projects + overall project notebooks)
- •User wants comparative analysis across different documentation sets
- •User asks to "check all notebooks", "ask all my docs", etc.
- •User wants comprehensive view across entire knowledge base
Output format:
- •Displays answers from each notebook separately
- •Includes success/failure status for each
- •Provides unified view for synthesis
- •Same follow-up mechanism applies
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:
bash
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]
Cross-Notebook Analysis (ask_multiple.py)
# Query all notebooks python scripts/run.py ask_multiple.py --question "..." --all-notebooks # Query specific notebooks by ID (comma-separated) python scripts/run.py ask_multiple.py --question "..." --notebook-ids "id1,id2,id3" # Show browser python scripts/run.py ask_multiple.py --question "..." --all-notebooks --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
.venvautomatically - •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
- •Cross-notebook for hierarchies - Use
ask_multiple.pyfor project structures with sub-projects - •Specific vs. all notebooks - Use
--notebook-idsfor targeted analysis,--all-notebooksfor comprehensive view
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- Query single notebook - •
ask_multiple.py- Cross-notebook analysis - •
notebook_manager.py- Library management - •
auth_manager.py- Authentication - •
cleanup_manager.py- Data cleanup
- •
- •
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