我让openclaw做了一个 B 站弹幕分析SKILL:自动抓取 + 词云 + 情感分析 + 舆情报告(开源)

我让openclaw做了一个 B 站弹幕分析SKILL:自动抓取 + 词云 + 情感分析 + 舆情报告(开源)

大家好,最近我让openclaw把我自己在内容运营里常用的一套“弹幕分析流程”做成了一个可复用的小项目:

👉 bilibili-danmaku
GitHub:https://github.com/Smartloe/bilibili-danmaku

核心目标很直接:

  • 给我一个 B 站视频链接
  • 自动抓取弹幕
  • 自动做分词清洗
  • 自动输出词云图 + 情感分析 + 舆情报告

适合做内容复盘、热点观察、用户反馈提炼。


一、这个项目解决了什么问题?

日常做视频复盘时,常见痛点是:

  1. 弹幕采集麻烦:每次手动导出/复制,效率很低。
  2. 词云质量不稳定:不清洗会被“哈哈哈/666/这边那边”污染。
  3. 舆情判断缺标准:没有统一口径,沟通时容易“拍脑袋”。

这个项目把整条链路打通了:

抓取 → 清洗 → 关键词 → 词云 → 情感 → 报告

二、功能特性

  • ✅ 自动解析 BVID -> CID,抓取弹幕 XML
  • ✅ 导出结构化数据:CSV / JSON / TXT
  • jieba 分词 + 干扰词清洗
  • SnowNLP 情感分析(正/中/负分布)
  • wordcloud 生成高密度中文词云 PNG
  • ✅ 自动生成 Markdown 舆情报告

三、项目结构

bilibili-danmaku/ ├── SKILL.md ├── README.md ├── README.en.md ├── requirements.txt ├── scripts/ │ ├── ensure_env.sh │ ├── fetch_danmaku.py │ ├── fetch.sh │ ├── analyze_danmaku.py │ └── analyze.sh ├── references/ │ ├── methodology.md │ └── stopwords.default.txt └── output/ 

四、在 OpenClaw 里一键使用(推荐)

如果你本身就在用 OpenClaw,最省事的方式是直接从 ClawHub 安装:

clawhub install bilibili-danmaku 

安装后开启一个新的 OpenClaw 会话,直接给视频链接即可调用技能完成:

  • 弹幕抓取
  • 词云生成
  • 情感分析
  • 舆情报告输出

五、源码方式(3 步)

1)安装依赖

cd bilibili-danmaku bash scripts/ensure_env.sh 

2)抓取弹幕

python3 scripts/fetch_danmaku.py \--url"https://www.bilibili.com/video/BV17JfuBqEqg"\--outdir"./output"

支持短链:

python3 scripts/fetch_danmaku.py --url"https://b23.tv/gO0nMGs"--outdir"./output"

3)分析并出报告

bash scripts/analyze.sh \"./output/<xxx>_danmaku.csv"\"./output/<xxx>_meta.json"\"./output"\"task_name"

输出文件:

  • task_name_top_words.json
  • task_name_sentiment.json
  • task_name_wordcloud.png
  • task_name_report.md

六、为什么这版词云更“干净”?

我在分词后做了数据清洗,重点是四件事:

  1. 停用词过滤:默认词表 + 自定义词表
  2. 噪声词过滤:比如 哈哈哈 / 233 / 666 / 纯符号
  3. token 规范化:别名合并、重复字符压缩
  4. 高文档频率短词剔除:去掉“出现太广但信息量低”的词

你还可以临时追加干扰词:

./.venv/bin/python scripts/analyze_danmaku.py \--csv"./output/<xxx>_danmaku.csv"\--meta"./output/<xxx>_meta.json"\--outdir"./output"\--name"task_clean"\ --extra-stopwords "妈妈,亲戚,那边,这边"

七、情感分析怎么做?

使用 SnowNLP,每条弹幕都会得到一个 0~1 的情绪分:

  • >= 0.60:positive
  • <= 0.40:negative
  • 中间:neutral

最后汇总成:

  • 正向/中性/负向占比
  • 平均情绪分
  • 代表性正负样本

这对“选题复盘”和“评论区风向判断”很实用。


八、适用场景

  • 内容运营:复盘某条视频的用户反馈
  • 新媒体团队:快速形成“可汇报”的舆情材料
  • 创作者:看粉丝关注点与争议点
  • 数据分析同学:做多视频横向对比

九、我自己的使用建议

如果你要把它用于日常工作流,我建议:

  1. 先跑单视频,确认数据链路与参数
  2. 再跑批量视频,做横向对比
  3. 维护一个自己的 stopwords 词表(按垂类持续迭代)
  4. 报告里优先看三件事:
    • 情绪结构是否异常
    • 高频词是否偏离内容定位
    • 负向样本是否集中在某个可改进点

十、开源地址

如果你刚好也在做内容分析,欢迎直接拿去用:

🔗 GitHub:https://github.com/Smartloe/bilibili-danmaku

欢迎提 issue / PR,一起把它打磨成更顺手的中文内容分析工具。🚀


十一、免责声明

请遵守 B站平台规则与相关法律法规。
本项目仅用于公开数据分析与研究,不用于违规抓取和滥用。

Read more

java: 警告: 源发行版 17 需要目标发行版 17

错误 java: 警告: 源发行版 17 需要目标发行版 17 要解决“java: 无效的目标发行版: 17”错误,需从JDK版本、构建工具配置、环境变量、IDE设置、依赖兼容性五个维度系统性排查。以下是具体步骤和解决方案: 一、验证JDK版本与一致性 1. 安装JDK 17: * 官方下载:Oracle JDK 17 * 开源替代:Adoptium Temurin JDK 17 验证构建工具使用的JDK: mvn -v# Maven使用的JDK版本 gradle -v# Gradle使用的JDK版本 确保与项目配置的JDK 17一致。 检查已安装的JDK版本: java-version javac -version 确保输出显示JDK 17(如17.0.11)

By Ne0inhk
Java之Volatile 关键字全方位解析:从底层原理到最佳实践

Java之Volatile 关键字全方位解析:从底层原理到最佳实践

文章目录 * 课程导言 * 适用对象 * 学习目标 * 第一部分:从并发三要素看volatile的定位 * 1.1 并发编程的三座大山 * 1.2 volatile的坐标:轻量级的同步利器 * 1.3 一个先导案例:感受volatile的魔力 * 第二部分:volatile与Java内存模型(JMM) * 2.1 为什么要JMM? * 2.2 JMM的核心结构:主内存 vs 工作内存 * 2.3 可见性问题的根源 * 2.4 volatile如何保证可见性? * 2.5 JMM对volatile的规范 * 第三部分:有序性与指令重排序 * 3.1 什么是指令重排序? * 3.2 重排序的潜在风险 * 3.3 volatile如何禁止重排序? * 3.

By Ne0inhk

Java最新面试题(全网最全、最细、附答案)

Java 最新面试题(2026 年版 · 全网最全、最细、附答案) 以下内容基于 2025 下半年 ~ 2026 年初 真实大厂(字节、阿里、腾讯、美团、华为、京东、快手、小米等)面经 + JDK 21/22/23 新特性趋势整理。 答案力求准确、简洁、可背诵、可展开,适合三面、四面、技术终面使用。 分为八大模块,按面试出现频率从高到低排序。 一、Java 基础 & JDK 新特性(2026 年常考 JDK 21–23) * Tomcat / Spring WebFlux

By Ne0inhk
Springboot 整合 Java DL4J 打造自然语言处理之智能写作助手

Springboot 整合 Java DL4J 打造自然语言处理之智能写作助手

🧑 博主简介:ZEEKLOG博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/literature?__c=1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编程,高并发设计,Springboot和微服务,熟悉Linux,ESXI虚拟化以及云原生Docker和K8s,热衷于探索科技的边界,并将理论知识转化为实际应用。保持对新技术的好奇心,乐于分享所学,希望通过我的实践经历和见解,启发他人的创新思维。在这里,我希望能与志同道合的朋友交流探讨,共同进步,一起在技术的世界里不断学习成长。

By Ne0inhk