Skip to content

Nonebot2插件,推送B站UP的动态更新和开播消息。

License

Notifications You must be signed in to change notification settings

Variante/nonebot-plugin-bilibili-notifier

Repository files navigation

NoneBotPluginLogo

NoneBotPluginText

nonebot-plugin-bilibili-notifier

✨ B站UP的更新与开播通知机 ✨

license pypi python

📖 介绍

B站UP的更新与开播通知机,默认每分钟爬取一次B站账号的动态与直播列表,将设置好的特定UP的更新或开播信息推送到QQ群里。

理论上适配SAA支持的各种协议,实测了Onebot v11协议成功。

💿 安装

使用 nb-cli 安装 在 nonebot2 项目的根目录下打开命令行, 输入以下指令即可安装
nb plugin install nonebot-plugin-bilibili-notifier
使用包管理器安装 在 nonebot2 项目的插件目录下, 打开命令行, 根据你使用的包管理器, 输入相应的安装命令
pip
pip install nonebot-plugin-bilibili-notifier
pdm
pdm add nonebot-plugin-bilibili-notifier
poetry
poetry add nonebot-plugin-bilibili-notifier
conda
conda install nonebot-plugin-bilibili-notifier

打开 nonebot2 项目根目录下的 pyproject.toml 文件, 在 [tool.nonebot] 部分追加写入

plugins = ["nonebot_plugin_bilibili_notifier"]

⚙️ 配置

首先用你的B站账号关注这些你想要追踪的UP主,并记住TA们的B站数字ID(以下简称BID):(点击主页后地址中显示的space.bilibili.com/[中的这个号码])。

然后导出B站cookies,建议使用Firefox的Export cookie JSON file for Puppeteer插件直接生成JSON文件,如果想手动生成,请确保以下字段有效:

{
  "sessdata": "",
  "bili_jct": "",
  "buvid3": "",
  "dedeuserid": "" 
}

建议导出cookies时使用和常用的浏览器不同的浏览器(或匿名模式),不然B站会定时要求刷新你的cookies。

在 nonebot2 项目的.env文件中添加下表中的必填配置

配置项 必填 默认值 说明
bnotifier_cookies 上面导出的B站cookies的文件路径
bnotifier_push_updates {} 设置追踪更新的UP主的ID)以及要推送的QQ群号,格式为{: [QQ群号1, QQ群号2, ...], ...}。注意全部号码都应为字符串,一个例子:{"823532": ["xxxxx", "yyyyy"]}
bnotifier_push_updates_by_group {} 作用同bnotifier_push_updates但格式为{QQ群: [BID1, BID2, ]},选择一个更适合你的方式即可
bnotifier_push_lives {} 同bnotifier_push_updates但这个变量控制的是开播通知
bnotifier_push_lives_by_group {} 格式同bnotifier_push_updates_by_group但这个变量控制的是开播通知
bnotifier_push_type_blacklist {} 屏蔽推送某种动态信息,格式:{QQ群号或BID: ['DYNAMIC_TYPE_AV', 'DYNAMIC_TYPE_FORWARD', ...]}这样会屏蔽特定群/特定up的某种动态信息。关于动态种类请参考这个连接
bnotifier_msg_truncate 256 将一条非常长的动态截短到设定的长度

其它配置为开发调试时使用,正常使用无需调整。

效果图

Notifier Demo

其它

有问题或新功能需求,请提issue。

About

Nonebot2插件,推送B站UP的动态更新和开播消息。

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages