notebooklm

安装量: 3.3K
排名: #665

安装

npx skills add https://github.com/pleaseprompto/notebooklm-skill --skill notebooklm
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

返回排行榜