视频链接解析,并根据其内容生成基本信息、词云和内容总结
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 | 使用的缓存类型,可用类型包含 json 和 mongodb |
bilichat_text_fonts | str | default | 可供自定义的字体,仅作用于 dynamicrender 绘图 |
bilichat_emoji_fonts | str | default | 可供自定义的字体,仅作用于 dynamicrender 绘图 |
注:
- 由于 OneBot 协议未规定是否应上报自身事件,因此在不同的场景下能否获取自身事件并不一定,
bilichat_enable_self
实际能否生效也与之相关 - 当
bilichat_whitelist
存在时,bilichat_blacklist
将会被禁用 bilichat_dynamic_font
可填写自定义的字体 url,但并不推荐修改- 当使用
bcut_asr
接口来生成 AI 字幕时,根据视频时长和网络情况有可能会识别失败,Bot 会提示BCut-ASR conversion failed due to network error
。可以通过调高bilichat_neterror_retry
次数或几分钟后重试来尝试重新生成字幕 - 当
bilichat_cache_serive
为mongodb
时,需要安装并配置 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),其可用的样式如下所示
bilichat_dynamic_style 除默认的 dynamicrender 使用 Skia 绘图(未开启浏览器时默认选择),其他均依赖于浏览器进行渲染(需要设置 bilichat_use_browser 为 True 或 Auto),其可用的样式如下所示
开启此功能需要安装对应的依赖 nonebot-plugin-bilichat[wordcloud]
配置项 | 类型 | 默认值 | 说明 |
---|---|---|---|
bilichat_word_cloud | bool | False | 是否开启词云功能 |
注:词云功能在 python3.11 中由于 wordcloud
包安装失败暂时无法启用,请不要在 3.11 中开启此功能
开启此功能需要安装对应的依赖 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 ,可自行替换 |
注:
- openai 与 newbing 目前均需求科学上网才能使用,国内服务器请务必填写
bilichat_openai_proxy
或全局透明代理 - 如果同时填写了
bilichat_openai_token
和bilichat_newbing_cookie
,则会使用newbing
进行总结, 并在newbing
总结失败时使用openai
进行总结 newbing
和openai
均有缓存机制,同一视频在获取到正常的总结内容后不会重复发送请求,如需刷新请求内容可以 添加参数 或手动删除对应视频的缓存文件或整个缓存文件夹- 经测试,目前
newbing
至少能总结 12000 字符以上的文本,推测 token 上限应为gpt-4-32k-0314
的32200
token,但过长的内容易造成输出内容包含额外内容或总结失败,因此也建议设置一个合理的 token 上限(反正不要钱,要啥自行车) - 由于
newbing
限制较大,也不如openai
听话,且需要联网查询资料,因此使用体验并不如 chatgpt(反正不要钱,要啥自行车) - newbing cookie 文件获取方式参考这里和这里。
目前 newbing 已正式公布且无需登录也可使用,填写目前无 cookie 使用失败概率极高,请谨慎考虑是否采用无 cookie 的方式。bilichat_newbing_cookie=no_login
即可无 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 站,防止风控 |
在此感谢以下开发者(项目)对本项目做出的贡献:
- BibiGPT 项目灵感来源
- bilibili-API-collect 易姐收集的各种 BiliBili Api 及其提供的 gRPC Api 调用方案
- BBot-Graia 功能来源
(我 牛 我 自 己) - ABot-Graia 永远怀念最好的 ABot 🙏
- nonebot-plugin-template: 项目的 README 模板
- nonebot-plugin-bing-chat: newbing 解析的代码参考
- Misaka-Mikoto-Tech 为本项目提交了多项 BUG 修复和代码参考
- hamo-reid 为 style_blue 绘制了界面
- dynamicrender 提供 t2i 和动态渲染