Skip to content

一个通过 OpenAI 来对b站视频进行总结的多功能 B站解析插件

License

Notifications You must be signed in to change notification settings

forchannot/nonebot-plugin-bilichat

 
 

Repository files navigation

NoneBotPluginLogo

NoneBotPluginText

nonebot-plugin-bilichat

✨ 多功能的 B 站视频解析工具 ✨

license PyPI - Downloads pypi python pdm-managed Code style: black onebot onebot QQ Chat Group QQ Chat Group

📖 介绍

视频链接解析,并根据其内容生成基本信息词云内容总结

手机端视图

基本信息

bbot_default

style_blue

词云

视频总结

💿 安装

Linux 用户在安装时如果出现 libGL.so.1: cannot open shared object file: No such file or directory 错误,说明缺少 OpenGL 的运行环境,可以参考 dynamicrender 中的 README 安装对应的依赖后重试

使用 nb-cli 安装 在 nonebot2 项目的根目录下打开命令行, 输入以下指令即可安装
nb plugin install nonebot-plugin-bilichat

注: 由于 nb-cli 不支持依赖组,因此需要启用词云和 AI 总结的用户要通过其他的包管理器安装额外的依赖

pip install nonebot-plugin-bilichat[all]
使用包管理器安装 在 nonebot2 项目的插件目录下, 打开命令行, 根据你使用的包管理器, 输入相应的安装命令
pip
pip install nonebot-plugin-bilichat[all]
pdm
pdm add nonebot-plugin-bilichat[all]
poetry
poetry add nonebot-plugin-bilichat[all]
conda
conda install nonebot-plugin-bilichat[all]

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

plugins = ["nonebot_plugin_bilichat"]

⚙️ 配置

在 nonebot2 项目的.env文件中添加下表中的配置, 配置均为非必须项

太长不看版

一般来说,你只需要关注以下几个配置项

# 对同一视频的响应冷却时间(防止刷屏)
bilichat_cd_time = 120
# 网络请求重试次数
bilichat_neterror_retry = 3
# 是否使用浏览器截图
bilichat_use_browser = True

# 是否开启词云
bilichat_word_cloud = True

# === AI 总结相关 ===
# newbing cookies
bilichat_newbing_cookie = "cookies.json"
# openai token
bilichat_openai_token = sk-xxxxxxx
# 网络代理
bilichat_openai_proxy = "http://127.0.0.1:7890/"

通用配置项

配置项 类型 默认值 说明
bilichat_block bool False 是否拦截事件(防止其他插件二次解析)
bilichat_enable_self bool False 是否允许响应自身的消息
bilichat_only_self bool False 是否仅响应自身的消息,开启后会覆盖全部其他规则(人机合一特供)
bilichat_only_to_me bool False 非自身消息是否需要 @机器人 或使用机器人的昵称才响应
bilichat_whitelist list[str] [] 响应的会话名单, 会覆盖黑名单
bilichat_blacklist list[str] [] 不响应的会话名单
bilichat_dynamic_font str None 视频信息及词云图片使用的字体
bilichat_cd_time int 120 对同一视频的响应冷却时间(防止刷屏)
bilichat_neterror_retry int 3 对部分网络请求错误的尝试次数
bilichat_use_bcut_asr bool True 是否在没有字幕时调用必剪接口生成字幕
bilichat_show_error_msg bool True 是否在解析失败时发送错误信息
bilichat_use_browser bool Auto 是否使用浏览器,Auto 会根据是否含有相应的依赖进行选择
bilichat_cache_serive str Auto 使用的缓存类型,可用类型包含 jsonmongodb
bilichat_text_fonts str default 可供自定义的字体,仅作用于 dynamicrender 绘图
bilichat_emoji_fonts str default 可供自定义的字体,仅作用于 dynamicrender 绘图

注:

  1. 由于 OneBot 协议未规定是否应上报自身事件,因此在不同的场景下能否获取自身事件并不一定,bilichat_enable_self 实际能否生效也与之相关
  2. bilichat_whitelist 存在时,bilichat_blacklist 将会被禁用
  3. bilichat_dynamic_font 可填写自定义的字体 url,但并不推荐修改
  4. 当使用 bcut_asr 接口来生成 AI 字幕时,根据视频时长和网络情况有可能会识别失败,Bot 会提示 BCut-ASR conversion failed due to network error。可以通过调高 bilichat_neterror_retry 次数或几分钟后重试来尝试重新生成字幕
  5. bilichat_cache_serivemongodb 时,需要安装并配置 nonebot-plugin-mongodb 才可正常使用

指令及订阅配置项

配置项 类型 默认值 说明
bilichat_subs_limit int 5 允许的最大订阅数(0-50)
bilichat_subs_interval int 30 允许的订阅间隔(30-600 秒)
bilichat_dynamic_grpc bool False 是否使用 gRPC 刷取动态
bilichat_command_to_me bool True 命令是否需要@机器人
bilichat_cmd_start str "bilichat" 命令的起始词,可设置为空
bilichat_cmd_add_sub List[str] {"订阅", "关注"} "sub"命令的别名
bilichat_cmd_remove_sub List[str] {"退订", "取关"} "unsub"命令的别名
bilichat_cmd_check_sub List[str] {"查看", "查看订阅"} "check"命令的别名
bilichat_cmd_at_all List[str] {"全体成员", "at 全体"} "atall"命令的别名

基础信息配置项

配置项 类型 默认值 说明
bilichat_basic_info bool True 是否开启视频基本信息
bilichat_basic_info_style str Auto 视频详情的图片样式,可用样式见下方备注
bilichat_basic_info_url bool True 开启视频进本信息的情况下,是否一同回复一个链接
bilichat_reply_to_basic_info bool True 后续消息是否回复基础信息(关闭则回复发送者的信息)
bilichat_dynamic bool True 是否开启动态解析
bilichat_dynamic_style str Auto 动态详情的图片样式,可用样式见下方备注
bilichat_bilibili_cookie str None bilibili 的 cookie 文件路径,api 则自动创建空文件
bilichat_bilibili_cookie_api str None 在运行时更新 bilibili cookie,使用方法参考这里

bilichat_basic_info_style 除默认的 bbot_default 使用 PIL 绘图(未开启浏览器时默认选择),其他均依赖于浏览器进行渲染(需要设置 bilichat_use_browser 为 True 或 Auto),其可用的样式如下所示

bbot_default (无浏览器时默认)

style_blue (有浏览器时默认)

bilichat_dynamic_style 除默认的 dynamicrender 使用 Skia 绘图(未开启浏览器时默认选择),其他均依赖于浏览器进行渲染(需要设置 bilichat_use_browser 为 True 或 Auto),其可用的样式如下所示

dynamicrender (无浏览器时默认)

browser_mobile (有浏览器时默认)

browser_pc

词云配置项

开启此功能需要安装对应的依赖 nonebot-plugin-bilichat[wordcloud]

配置项 类型 默认值 说明
bilichat_word_cloud bool False 是否开启词云功能

注:词云功能在 python3.11 中由于 wordcloud 包安装失败暂时无法启用,请不要在 3.11 中开启此功能

AI 视频总结配置项

开启此功能需要安装对应的依赖 nonebot-plugin-bilichat[summary]

配置项 类型 默认值 说明
bilichat_newbing_cookie str None newbing 的 cookie 文件路径, 填写 no_login 则不登录,api 则自动创建空文件, 若留空则禁用 newbing 总结
bilichat_newbing_cookie_api str None 在运行时更新 newbing cookie,使用方法参考这里
bilichat_newbing_token_limit int 0 newbing 请求的文本量上限, 0 为无上限
bilichat_newbing_preprocess bool True 是否对 newbing 的返回值进行预处理, 以去除其中不想要的内容
bilichat_newbing_wss_link str see description 默认为 wss://sydney.bing.com/sydney/ChatHub,可自行替换
bilichat_openai_token str None openai 的 apikey, 若留空则禁用 openai 总结
bilichat_openai_proxy str None 访问 openai 或 newbing 使用的代理地址
bilichat_openai_model str gpt-3.5-turbo-0301 使用的语言模型名称
bilichat_openai_token_limit int 3500 请求的文本量上限, 计算方式可参考tiktoken
bilichat_openai_api_base str see description 默认为 https://api.openai.com,可自行替换

注:

  1. openai 与 newbing 目前均需求科学上网才能使用,国内服务器请务必填写 bilichat_openai_proxy 或全局透明代理
  2. 如果同时填写了 bilichat_openai_tokenbilichat_newbing_cookie,则会使用 newbing 进行总结, 并在 newbing 总结失败时使用 openai 进行总结
  3. newbingopenai 均有缓存机制,同一视频在获取到正常的总结内容后不会重复发送请求,如需刷新请求内容可以 添加参数 或手动删除对应视频的缓存文件或整个缓存文件夹
  4. 经测试,目前 newbing 至少能总结 12000 字符以上的文本,推测 token 上限应为 gpt-4-32k-031432200 token,但过长的内容易造成输出内容包含额外内容或总结失败,因此也建议设置一个合理的 token 上限 (反正不要钱,要啥自行车)
  5. 由于 newbing 限制较大,也不如 openai 听话,且需要联网查询资料,因此使用体验并不如 chatgpt (反正不要钱,要啥自行车)
  6. newbing cookie 文件获取方式参考这里这里目前 newbing 已正式公布且无需登录也可使用,填写 bilichat_newbing_cookie=no_login 即可无 cookie 使用。 目前无 cookie 使用失败概率极高,请谨慎考虑是否采用无 cookie 的方式。

🎉 使用

直接发送视频(专栏)链接即可

参数表

在发送视频时,可以额外添加以下类似 shell 指令的参数,进而对解析流程进行调整。例如

BV12v4y1E7NT --refresh
BV12v4y1E7NT -r # 可以使用简写
BV12v4y1E7NT -r --no-cache # 可以多个参数混用
-r BV12v4y1E7NT -n # 虽然不建议,但确实可以把参数放前面
指令 简写 说明
--no-cache -n 本次总结禁用缓存(不会影响已存在的缓存文件)
--refresh -r 刷新此视频的词云和总结缓存(会覆盖已存在的缓存文件)

指令表

此部分当前仅适配了 OneBot 11 ,如果有其他适配器的需求可以新建 issue 来提出

指令部分由 指令前缀指令名 组成,其中 指令前缀 包含 COMMAND_START bilichat_cmd_start COMMAND_SEP 三部分,默认的 指令前缀/bilichat. ,即完整的指令为 /bilichat.xxx

指令前缀 部分也是可以修改的,例如 .env 中填入如下设置即可实现无 指令前缀

COMMAND_SEP=[""]
COMMAND_START=[""]
bilichat_cmd_start=""

指令名 如下表所示,其中除登录相关的指令均可自定义,可参考上文的 指令及订阅配置项

指令 权限 范围 参数 说明
sub 主人 群聊 UP 主的昵称或 UID 添加订阅
unsub 主人 群聊 UP 主的昵称或 UID 移除订阅
check 无限制 群聊 查看本群订阅
atall 主人 群聊 UP 主的昵称或 UID,或 全局 设置是否 at 全体成员,仅 OB11 有效
smslogin 主人 无限制 使用验证码登录 B 站,防止风控
qrlogin 主人 无限制 使用二维码登录 B 站,防止风控

🙏 感谢

在此感谢以下开发者(项目)对本项目做出的贡献:

⏳ Star 趋势

Stargazers over time

About

一个通过 OpenAI 来对b站视频进行总结的多功能 B站解析插件

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 91.0%
  • HTML 4.6%
  • JavaScript 4.4%