🎯

notebooklm

🎯Skill

from zhanlincui/ultimate-agent-skills-collection

VibeIndex|
What it does

Queries Google NotebookLM notebooks to retrieve source-grounded, citation-backed answers from Gemini using browser automation and persistent authentication.

πŸ“¦

Part of

zhanlincui/ultimate-agent-skills-collection(42 items)

notebooklm

Installation

PythonRun Python server
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]"
PythonRun Python server
python scripts/run.py notebook_manager.py add --url "[URL]" --name "[Based on content]" --description "[Based on content]" --topics "[Based on content]"
PythonRun Python server
python scripts/run.py auth_manager.py status
PythonRun Python server
python scripts/run.py notebook_manager.py list
PythonRun Python server
python scripts/run.py ask_question.py --question "..."

+ 27 more commands

πŸ“– Extracted from docs: zhanlincui/ultimate-agent-skills-collection
5Installs
-
AddedFeb 4, 2026

Skill Details

SKILL.md

Use this skill to query your Google NotebookLM notebooks directly from Claude Code for source-grounded, citation-backed answers from Gemini. Browser automation, library management, persistent auth. Drastically reduced hallucinations through document-only responses.

Overview

# 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:

```bash

# 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]:

```bash

# βœ… 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:

  1. Creates .venv if needed
  2. Installs all dependencies
  3. Activates environment
  4. Executes script properly

Core Workflow

Step 1: Check Authentication Status

```bash

python scripts/run.py auth_manager.py status

```

If not authenticated, proceed to setup.

Step 2: Authenticate (One-Time Setup)

```bash

# 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

```bash

# 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

  1. Check library: python scripts/run.py notebook_manager.py list
  2. Ask question: python scripts/run.py ask_question.py --question "..." --notebook-id ID

Step 4: Ask Questions

```bash

# 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:

  1. STOP - Do not immediately respond to user
  2. ANALYZE - Compare answer to user's original request
  3. IDENTIFY GAPS - Determine if more information needed
  4. ASK FOLLOW-UP - If gaps exist, immediately ask:

```bash

python scripts/run.py ask_question.py --question "Follow-up with context..."

```

  1. REPEAT - Continue until information is complete
  2. SYNTHESIZE - Combine all answers before responding to user

Script Reference

Authentication Management (`auth_manager.py`)

```bash

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`)

```bash

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`)

```bash

python scripts/run.py ask_question.py --question "..." [--notebook-id ID] [--notebook-url URL] [--show-browser]

```

Data Cleanup (`cleanup_manager.py`)

```bash

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):

```bash

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:

```env

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

  1. Always use run.py - Handles environment automatically
  2. Check auth first - Before any operations
  3. Follow-up questions - Don't stop at first answer
  4. Browser visible for auth - Required for manual login
  5. Include context - Each question is independent
  6. 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

More from this repository10

🎯
ui-ux-pro-max🎯Skill

Generates comprehensive UI/UX design intelligence with 50+ styles, 9 tech stacks, and actionable recommendations for creating accessible, performant, and visually appealing web and mobile interfaces.

🎯
web-performance-seo🎯Skill

web-performance-seo skill from zhanlincui/ultimate-agent-skills-collection

🎯
systematic-debugging🎯Skill

Systematically investigates root causes of technical issues by carefully reproducing problems, analyzing errors, and gathering comprehensive diagnostic evidence before proposing any fixes.

🎯
receiving-code-review🎯Skill

Systematically evaluates and verifies code review feedback, asking clarifying questions and responding with technical rigor before implementation.

🎯
vercel-react-best-practices🎯Skill

Provides AI-guided performance optimization recommendations for React and Next.js applications, following Vercel's engineering best practices across critical performance categories.

🎯
web-design-guidelines🎯Skill

Provides comprehensive web design best practices, standards, and actionable guidelines for creating visually appealing and user-friendly websites across different design dimensions.

🎯
requesting-code-review🎯Skill

Systematically request code reviews from a specialized subagent to validate work, catch issues early, and ensure quality before merging or proceeding.

🎯
algorithmic-art🎯Skill

Generates algorithmic art philosophies and p5.js sketches by exploring computational aesthetics, emergent behaviors, and seeded randomness.

🎯
docx🎯Skill

Generates, edits, and analyzes Microsoft Word documents (.docx) with advanced capabilities like tracked changes, comments, and text extraction.

🎯
json-canvas🎯Skill

Generates and manipulates JSON Canvas files with nodes, edges, and groups for visual mapping and organizing information.