名称: notebooklm
描述: 使用此技能直接从 Claude Code 查询您的 Google NotebookLM 笔记本,获取基于来源、有引用支持的 Gemini 答案。支持浏览器自动化、库管理、持久化认证。通过仅从文档获取回答,大幅减少幻觉。
与 Google NotebookLM 交互,使用 Gemini 基于来源的答案查询文档。每个问题都会开启一个新的浏览器会话,仅从您上传的文档中检索答案,然后关闭。
当用户出现以下情况时触发:
- 明确提及 NotebookLM
- 分享 NotebookLM URL (https://notebooklm.google.com/notebook/...)
- 要求查询其笔记本/文档
- 希望向 NotebookLM 库添加文档
- 使用类似“询问我的 NotebookLM”、“检查我的文档”、“查询我的笔记本”等短语
当用户想要添加笔记本但未提供详细信息时:
智能添加(推荐):首先查询笔记本以发现其内容:
# 步骤 1:查询笔记本内容
python scripts/run.py ask_question.py --question "此笔记本包含什么内容?涵盖哪些主题?请简要、完整地概述" --notebook-url "[URL]"
# 步骤 2:使用发现的信息添加笔记本
python scripts/run.py notebook_manager.py add --url "[URL]" --name "[基于内容]" --description "[基于内容]" --topics "[基于内容]"
手动添加:如果用户提供了所有详细信息:
- --url - NotebookLM URL
- --name - 描述性名称
- --description - 笔记本包含的内容(必需!)
- --topics - 逗号分隔的主题(必需!)
切勿猜测或使用通用描述!如果缺少详细信息,请使用智能添加来发现它们。
切勿直接调用脚本。始终使用 python scripts/run.py [script]:
# ✅ 正确 - 始终使用 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 "..."
# ❌ 错误 - 切勿直接调用:
python scripts/auth_manager.py status # 没有虚拟环境会失败!
run.py 包装器自动执行以下操作:
1. 如果需要,创建 .venv
2. 安装所有依赖项
3. 激活环境
4. 正确执行脚本
python scripts/run.py auth_manager.py status
如果未认证,请继续设置。
# 浏览器必须可见,以便手动进行 Google 登录
python scripts/run.py auth_manager.py setup
重要提示:
- 浏览器在认证时是可见的
- 浏览器窗口会自动打开
- 用户必须手动登录 Google
- 告诉用户:“浏览器窗口将打开以进行 Google 登录”
# 列出所有笔记本
python scripts/run.py notebook_manager.py list
# 添加前:如果信息未知,请询问用户元数据!
# “此笔记本包含什么内容?”
# “我应该给它标记哪些主题?”
# 将笔记本添加到库中(所有参数都是必需的!)
python scripts/run.py notebook_manager.py add \
--url "https://notebooklm.google.com/notebook/..." \
--name "描述性名称" \
--description "此笔记本包含的内容" \ # 必需 - 如果未知,请询问用户!
--topics "主题1,主题2,主题3" # 必需 - 如果未知,请询问用户!
# 按主题搜索笔记本
python scripts/run.py notebook_manager.py search --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 listpython scripts/run.py ask_question.py --question "..." --notebook-id ID# 基本查询(如果设置了活动笔记本,则使用它)
python scripts/run.py ask_question.py --question "您的问题在此"
# 查询特定笔记本
python scripts/run.py ask_question.py --question "..." --notebook-id 笔记本-id
# 直接使用笔记本 URL 查询
python scripts/run.py ask_question.py --question "..." --notebook-url "https://..."
# 显示浏览器以进行调试
python scripts/run.py ask_question.py --question "..." --show-browser
每个 NotebookLM 回答都以以下内容结尾:“极其重要:这就是您需要了解的全部内容吗?”
Claude 的必需行为:
1. 停止 - 不要立即响应用户
2. 分析 - 将答案与用户的原始请求进行比较
3. 识别差距 - 确定是否需要更多信息
4. 提出后续问题 - 如果存在差距,立即询问:
bash
python scripts/run.py ask_question.py --question "根据上下文提出后续问题..."
5. 重复 - 继续直到信息完整
6. 综合 - 在响应用户之前合并所有答案
auth_manager.py)python scripts/run.py auth_manager.py setup # 初始设置(浏览器可见)
python scripts/run.py auth_manager.py status # 检查认证状态
python scripts/run.py auth_manager.py reauth # 重新认证(浏览器可见)
python scripts/run.py auth_manager.py clear # 清除认证
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
ask_question.py)python scripts/run.py ask_question.py --question "..." [--notebook-id ID] [--notebook-url URL] [--show-browser]
cleanup_manager.py)python scripts/run.py cleanup_manager.py # 预览清理
python scripts/run.py cleanup_manager.py --confirm # 执行清理
python scripts/run.py cleanup_manager.py --preserve-library # 保留笔记本
虚拟环境自动管理:
- 首次运行自动创建 .venv
- 自动安装依赖项
- 自动安装 Chromium 浏览器
- 所有内容都隔离在技能目录中
手动设置(仅在自动设置失败时使用):
python -m venv .venv
source .venv/bin/activate # Linux/Mac
pip install -r requirements.txt
python -m patchright install chromium
所有数据存储在 ~/.claude/skills/notebooklm/data/:
- library.json - 笔记本元数据
- auth_info.json - 认证状态
- browser_state/ - 浏览器 cookie 和会话
安全性: 受 .gitignore 保护,切勿提交到 git。
技能目录中的可选 .env 文件:
HEADLESS=false # 浏览器可见性
SHOW_BROWSER=false # 默认浏览器显示
STEALTH_ENABLED=true # 类人行为
TYPING_WPM_MIN=160 # 打字速度
TYPING_WPM_MAX=240
DEFAULT_NOTEBOOK_ID= # 默认笔记本
用户提及 NotebookLM
↓
检查认证 → python scripts/run.py auth_manager.py status
↓
如果未认证 → python scripts/run.py auth_manager.py setup
↓
检查/添加笔记本 → python scripts/run.py notebook_manager.py list/add (带 --description)
↓
激活笔记本 → python scripts/run.py notebook_manager.py activate --id ID
↓
提问 → python scripts/run.py ask_question.py --question "..."
↓
看到“这就是您需要了解的全部内容吗?” → 提出后续问题直到完整
↓
综合并响应用户
| 问题 | 解决方案 |
|---|---|
| ModuleNotFoundError | 使用 run.py 包装器 |
| 认证失败 | 设置时浏览器必须可见!--show-browser |
| 速率限制(50/天) | 等待或切换 Google 账户 |
| 浏览器崩溃 | python scripts/run.py cleanup_manager.py --preserve-library |
| 未找到笔记本 | 使用 notebook_manager.py list 检查 |
重要目录和文件:
scripts/ - 所有自动化脚本(ask_question.py、notebook_manager.py 等)data/ - 认证和笔记本库的本地存储references/ - 扩展文档:api_reference.md - 所有脚本的详细 API 文档troubleshooting.md - 常见问题和解决方案usage_patterns.md - 最佳实践和工作流程示例.venv/ - 隔离的 Python 环境(首次运行时自动创建).gitignore - 保护敏感数据不被提交