✨基于Nonebot2的图片/漫画翻译插件✨
通过pip
或nb
安装;
- 使用nb:
在机器人目录下命令行使用
nb plugin install nonebot_plugin_manga_translator
- 使用pip(不推荐):
pip install nonebot_plugin_manga_translator
之后在机器人pyproject.toml
里的plugins = []
列表追加"nonebot_plugin_manga_translator"
-
适配多种api,将收到的图片翻译并发送翻译后的图片,支持批量操作
-
本插件0.2.0版本开始基于nonebot-plugin-alconna插件,适配了多平台(不一定稳定,欢迎提issue或pr),之前的版本(<=0.1.3)支持onebot.v11适配器
为了适配多平台,从0.2.0以及之后的版本插件需要“客户端型驱动器”(如 httpx)来下载图片等,驱动器安装和配置参考 NoneBot 选择驱动器
我知道很少人会去看,所以你可以直接按照下面两步操作
首先找到你的平台协议需要的驱动器,大部分情况下可以httpx,例如
nb driver install httpx
并且需要在 .env.*
配置文件中启用对应的驱动器,例如:
DRIVER=~fastapi+~httpx
请在机器人目录下的.env.*里填写以下选项(至少填一个平台的),获取方式已整理好,见下方
个人感觉就漫画翻译而言,这几家API的效果大致为有道>=百度≈离线>=火山,且火山翻译对竖版日文的翻译效果很差
配置项 | 类型 | 默认值 | 示例 | 说明 | API定价 |
---|---|---|---|---|---|
有道翻译API | - | - | - | - | 新用户送一定额度,梯度收费,0<月调用量<100w时,0.04元/张 |
youdao_app_key | str | "" | youdao_app_key="xxxxx" | 应用ID | |
youdao_app_secret | str | "" | youdao_app_secret="xxxxxx" | 应用秘钥 | |
百度翻译API | - | - | - | - | 每月1万次免费调用量,之后按梯度收费,最高0.04元/次 |
baidu_app_id | str | "" | baidu_app_id="66666" | APP ID | |
baidu_app_key | str | "" | baidu_app_key="xxxxxx" | 密钥 | |
火山翻译API | - | - | - | - | 每月前100张免费,之后0.04元/张 |
huoshan_access_key_id | str | "" | huoshan_access_key_id="AK***" | Access Key ID | |
huoshan_secret_access_key | str | "" | huoshan_secret_access_key="UT**" | Secret Access Key | |
离线翻译API | - | - | - | - | 可能是电费? |
offline_url | str | "" | offline_url="http://127.0.0.1:5003" | 见下方说明 | |
其他翻译API(待更新) | - | - | - | - |
有道翻译
- 在有道智云AI开放平台注册并登录后,进入控制台
- 在左侧
自然语言翻译服务
里的图片翻译
里创建应用,选择服务和接入方式分别为图片翻译
和API
,其他项随意。 - 创建后将
应用ID
和应用秘钥
按照上面的配置说明分别填入.env.*文件里即可
百度翻译
- 在百度翻译开放平台注册并登录
- 找到
产品服务
的图片翻译
,申请创建 - 创建后在
管理控制台
的总览
中找到APP ID
和密钥
,根据上面的配置说明填入.env.*文件
火山翻译
- 根据火山引擎的文档,按流程注册
- 创建好服务后获取到密钥,分别为
Access Key ID
和Secret Access Key
,然后点击Secret Access Key
下的按钮显示出密钥 - 分别根据上面的配置说明填入.env.*文件
离线翻译
(该方案对设备配置要求较高,建议在有足够的硬盘空间、内存、显存,或有一台能为bot处理请求的服务器时考虑使用该方案)-
参考manga-image-translator的说明,克隆仓库,并安装相关依赖(可能需要额外安装
pydensecrf
) -
安装好依赖后,在仓库目录下运行
python -m manga_translator -v --mode web --use-cuda # the demo will be serving on http://127.0.0.1:5003,此时会提供一个网页,可以点击打开
-
如果你的设备没有成功安装cuda(要求pytorch的版本和cuda对应,不对应请重装),请去掉参数
--use-cuda
,如果图片处理过程中爆显存,请改成--use-cuda-limited
-
你可以访问控制台给出的网址,尝试先本地翻译一张图片,此时会根据选项下载需要的模型(为防止下载失败,也可以提前手动下载)
-
如果bot和翻译器在同一台设备,那么.env填写
offline_url="http://127.0.0.1:5003"
即可,如果不在同一台设备,你可能还需要放行防火墙、端口转发等,并且填写内容也会有所变化 -
最后你可能还需要修改一下本插件的代码,找到本插件
utils.py
的offline
函数,根据注释和文档,修改字典data
,从而指定你想要的OCR模型和翻译模型(目前是用了offline模型,你可以改成别的)
-
图片翻译 [图片]:单张图片翻译,也可以先发送/图片翻译再发送图片,可以如下组合
- 文字+图片
- 先文字,后图片
- 文字回复图片
-
多图片翻译 [图片]:n张图片翻译,将会以合并转发消息(如果平台支持,否则则一张一张发出)的形式发出,可以如下组合
- 先文字,后多张图片
- 文字+图片*n
-
切换翻译api [api]: 将该api优先级提到最高,目前有
youdao baidu huoshan offline
未完待续
点击展开
-
2024-08-17:
- 兼容pydantic V2
-
2024-04-23:
- 更新PIL版本,修复压缩png图片时失败
-
2024-04-23:
- 更新版本,这个版本起开始基于nonebot-plugin-alconna插件支持多适配器多平台(可能有bug),同时更新nonebot2依赖至2.2.0以上
-
2023-06-09:
- 更新插件元数据
-
2023-05-03:
- 更新说明文档
- 适配火山翻译api,你可以选择接入火山翻译提供的API
-
2023-05-01:
- 添加切换api的功能,你可以将某个api优先级设为最高
- 适配离线翻译apimanga-image-translator,现在你可以体验本地的翻译
-
2023-04-28:
- 插件发布
-
适配离线翻译模型manga-image-translator
-
支持更多API
-
多平台适配
-
优化代码
-
支持指定源语言和目标语言
-
完善插件