name: bilibili-auto-transcript
version: "4.0.0"
description: "B站视频转录+收藏夹扫描。三级降级(CC→AI→Qwen3-ASR),自动选模型(1.7B GPU / 0.6B CPU),AI摘要生成。"
homepage: https://clawhub.ai/54lynnn/bilibili-transcript
metadata:
{
"openclaw":
{
"emoji": "📼",
"requires": { "bins": ["yt-dlp", "ffmpeg", "curl"] },
"install":
[
{
"id": "venv",
"kind": "shell",
"command": "cd {{SKILL_DIR}} && python3 -m venv .venv && .venv/bin/pip install qwen-asr requests",
"label": "Setup virtual env & install Qwen3-ASR",
},
],
},
}
📼 Bilibili 视频转录 & 收藏夹自动扫描
双模式技能 — 可以手动转录单个视频,也可以定时扫描收藏夹自动处理。
模式一:手动转录
当你给我一个 B站链接时,我会自动执行转录。
用法:
bash scripts/bilibili_transcript.sh "https://www.bilibili.com/video/BVxxxxx/"
转录优先级(自动降级):
- ✅ 人工CC字幕(zh-CN, zh-TW, en, ja 等)→ 100%准确,秒出
- ✅ AI字幕(ai-zh, ai-en, ai-ja 等9种语言)→ 85-90%准确,秒出
- ✅ Qwen3-ASR 语音转文字(智能选模型)→ 有独显用 1.7B,无独显用 0.6B
Qwen3-ASR 智能模型选择:
| 条件 | 模型 | 中文 CER | 显存需求 |
|:----:|:----:|:--------:|:-------:|
| 有 NVIDIA/AMD GPU | Qwen3-ASR-1.7B | ~3.8% | 4-6 GB |
| 有 Apple Silicon (M1-M4) | Qwen3-ASR-1.7B (MLX) | ~3.8% | 3-4 GB |
| 无独显 (CPU) | Qwen3-ASR-0.6B | ~5-7% | 2 GB 或不需 |
| 对比: Whisper medium | (旧版) | ~12% | 5-6 GB |
- 自动检测 CUDA / ROCm / Apple MPS / CPU
- 同一模型权重,自动切换计算后端
- 音频自动转为 16kHz 单声道 WAV(统一格式)
⚠️ 关键步骤(必须执行): 脚本运行后,AI必须先做这件事,才能向用户报告完成:
- 写摘要 →
read 输出的 TXT 文件,阅读全文,用 edit 替换占位符为结构化摘要
转录只负责出文件,索引那是 knowledge-rag 自己的事。
模式二:收藏夹自动扫描
定时检查 B站收藏夹,发现新视频后自动完成「转录 → AI 摘要 → 保存 → 通知」全流程。
工作流
定时触发 → 扫描收藏夹API → 对比已处理列表
→ 发现新视频 → 转录(三级降级)
→ (可选)AI读全文、写结构化摘要
→ 覆盖TXT中的摘要占位符
→ 记录avid到已处理列表
→ 生成转录报告CSV
→ 通知用户(标题/作者/时长/转录来源/摘要/TXT文件)
批量转录(推荐)
.venv/bin/python3 scripts/batch_transcribe.py
自动扫描收藏夹全部视频,逐个转录,支持:
- 断点续传 — 中断后重跑自动跳过已处理视频
- 自动重试 — 失败任务自动重试2次
- 转录报告 — 生成 CSV 报告,含来源分布统计
- AI摘要 — 可选,设置环境变量
OPENAI_API_KEY 即可自动生成摘要 - 目录组织 — 按视频发布年月自动分目录存储
首次设置
1. 安装依赖
在技能目录下创建虚拟环境并安装依赖:
cd ~/.openclaw/workspace/skills/bilibili-auto-transcript
python3 -m venv .venv
.venv/bin/pip install qwen-asr requests
2. 创建收藏夹
B站新建一个收藏夹,设为公开。
3. 获取收藏夹ID
URL 中 fid= 后面的数字。
4. 修改扫描脚本
编辑 scripts/bilibili_scanner.py,改 FAV_MEDIA_ID 为你的收藏夹ID。
5. Chromium 登录B站(获取Cookie)
chromium-browser &
# 打开 bilibili.com 并登录
6. 检查依赖
yt-dlp --version # 必需
ffmpeg -version # 必需
.venv/bin/python3 -c "from qwen_asr import Qwen3ASRModel; print('Qwen3-ASR OK')" # 必需
opencc --version # 可选,繁转简
7. 配置定时任务(推荐每6小时)
openclaw cron add \
--name bilibili-scan \
--every 21600000 \
--message "运行扫描脚本:cd ~/.openclaw/workspace/skills/bilibili-auto-transcript && .venv/bin/python3 scripts/bilibili_scanner.py"
公共部分
转录脚本
scripts/bilibili_transcript.sh — 两个模式共享同一个引擎(v4.0)。
scripts/qwen3_transcribe.py — Qwen3-ASR 转录辅助脚本(自动设备检测+模型选择)。
依赖
yt-dlp — 视频下载、字幕获取ffmpeg — 音频处理.venv/bin/python3 — 技能虚拟环境,内含 qwen-asr(语音转文字)、requests(HTTP请求)opencc — 繁转简(可选)chromium-browser — Cookie 支持(B站AI字幕)
输出文件格式
================================================================================
B站视频转录文档
================================================================================
📹 视频标题:xxx
🔗 B站链接:xxx
👤 作者:xxx
📅 发布时间:xxx
⏱️ 视频时长:xxx
📝 转录来源:CC字幕 / B站AI字幕 / Qwen3-ASR-1.7B(GPU加速)/ Qwen3-ASR-0.6B
⏰ 转录时间:xxx
================================================================================
第一部分:视频摘要(AI生成)
================================================================================
【AI待处理:请阅读全文后,替换此行,写结构化摘要】
(设置 OPENAI_API_KEY 后自动生成)
================================================================================
第二部分:完整原文
================================================================================
(完整转录内容...)
================================================================================
文档结束
================================================================================
配置参数
| 参数 | 默认值 | 说明 |
|------|--------|------|
| 收藏夹ID | (需设置) | URL fid= 的数字 |
| 输出目录 | ~/workspace/knowledge/bilibili/ | TXT存放路径,自动按年/月分子目录 |
| 已处理记录 | ~/.openclaw/workspace/.auto-transcript-state/processed_videos.txt | 去重文件(每行一个avid) |
| 转录报告 | ~/.openclaw/workspace/.auto-transcript-state/transcript_report.csv | 每次批量转录的详细报告 |
| 扫描间隔 | 每6小时 | 自动模式定时 |
| OPENAIAPIKEY | (可选) | 设置后自动生成AI摘要 |
B站收藏夹API
GET https://api.bilibili.com/x/v3/fav/resource/list?media_id={ID}&ps=20&pn=1
ps 最大20(脚本已设 ps=20)- 公开收藏夹无需Cookie
avid vs bvid
id = avid(数字)→ 去重追踪用bvid / bv_id = BV号 → 构建转录URL用
注意事项
- 同文件覆盖 — 同一BV号多次转录覆盖旧文件,已处理列表防重复
- 需要Cookie — 通过 Chromium cookie 获取 AI 字幕,需先B站登录;Cookie快过期时脚本会提示
- Qwen3-ASR 首次运行 — 首次使用时会自动从 HuggingFace 下载模型权重(0.6B ~2GB / 1.7B ~5GB),后续使用无需下载
- Qwen3-ASR 耗时 — GPU模式(1.7B)约实时 0.3x 倍速,CPU模式(0.6B)约实时 0.4x 倍速
- 虚拟环境 — 所有 Python 脚本需在
.venv 中运行:.venv/bin/python3 scripts/xxx.py;bilibili_transcript.sh 会自动检测并提示安装 - B站API ps上限20 — 超过需分页
- 摘要占位符必须替换 — 设置
OPENAI_API_KEY 环境变量可自动生成摘要 - 只干自己的事 — 转录只输出文件。索引是 knowledge-rag 的事情
- 输出目录 — 自 v3.0 起按视频发布年月自动组织目录(如
bilibili/2026/06/)
推荐搭配:📖 Knowledge RAG
装了这个 skill 后再装 knowledge-rag,知识库会定时自动扫描新文件并索引,无需手动操作:
clawhub install knowledge-rag
转录后自动索引,随时用自然语言搜索所有转过的内容,还有网页搜索界面。
📦 开源 & 交流