隐约雷鸣 阴霾天空 但盼风雨来 能留你在此

隐约雷鸣 阴霾天空 即使天无雨 我亦留此地

Docker SubFinder 自动刮削字幕器

《Docker SubFinder 自动刮削字幕器》

Docker SubFinder 自动刮削字幕器

本文是高阶教程-追剧全流程自动化的补充篇

自动刮削媒体文件字幕,打开容器后开始遍历媒体文件,遍历结束后休眠,之后每隔一小时遍历一次

Docker Hub:https://hub.docker.com/r/superng6/subfinder

GitHub:https://www.github.com/SuperNG6/docker-subfinder

博客:https://sleele.com/2020/04/09/subfinder/

本镜像根据:ausaki的 https://github.com/ausaki/subfinder 字幕查找器制作
具体的参数请参照subfinder的readme进行修改

1、配置文件subfinder.json位于/config/subfinder.json,请根据的你情况自行修改
2、计划任务配置subfinder-cron位于/config/subfinder-cron,请根据的你情况自行修改
2、去掉cron,改用sleep,降低使用难度,防止cron失效。现在设置更简单,env里设置TASK时间即可
s 为秒,m 为 分钟,h 为小时,d 为日数,默认2小时执行一次任务,例TASK=2h

{
   "exts": ["ass", "srt"],
   "method": ["shooter", "zimuzu", "zimuku"],
   "video_exts": [".mp4", ".mkv", ".iso"],
   "api_urls": {
      "zimuku": "http://www.zimuku.la/search",
      "zimuzu": "http://www.zmz2019.com/search",
      "zimuzu_subtitle_api_url": "http://got001.com/api/v1/static/subtitle/detail"
   }
}

# 官方说明文档

官方说明文档

参数含义必需
-l, --languages指定字幕语言,可同时指定多个。每个字幕查找器支持的语言不相同。具体支持的语言请看下文。否,subfinder 默认会下载字幕查找器找到的所有字幕。
-e, --exts指定字幕文件格式,可同时指定多个。每个字幕查找器支持的文件格式不相同。具体支持的文件格式请看下文。否,subfinder 默认会下载字幕查找器找到的所有字幕。
-m,--method指定字幕查找器,可同时指定多个。否,subfinder 默认使用 shooter 查找字幕。
--video_exts视频文件的后缀名(包括.,例如.mp4)
--repeat重复查找字幕,即使本地字幕已存在,默认False。
--exclude排除匹配模式的文件或目录,类似于shell的文件匹配模式。详情见下文
--api_urls指定字幕搜索器的API URL。详情见下文
-c,--conf配置文件否,SubFinder默认从~/.subfinder.json读取。
-s,--silence静默运行,不输出日志
--debug调试模式,输出调试日志
-h,--help显示帮助信息
  • --exclude, 支持的匹配模式类似于shell,* 匹配任意长度的字符串,? 匹配一个字符,[CHARS]匹配CHARS中的任一字符。例如:
  • 排除包含abc的目录:--exclude '*abc*/'。注意添加单引号,防止shell对其进行扩展。
  • 排除包含abc的文件:--exclude '*abc*'。注意和上个例子的区别,匹配目录时结尾有/目录分隔符,匹配文件则没有。
  • --api_urls
    字幕库的链接不太稳定,有时候会更换域名,因此提供--api_urls选项自定义API URL,以防域名或链接变动。
    --api_urls只接收JSON格式的字符串。
    获取正确的API URL的方法:
  • 字幕库的API一般形如 http://www.zimuku.la/search, 这个URL就是网页端“搜索”功能的URL。
  • 字幕组的API一般形如 http://www.zmz2019.com/search, 这个URL同样是网页端“搜索”功能的URL。
  • 射手网的API比较稳定,一般不会变动。
    配置示例:
   {
      // 设置字幕库的API
      "zimuku": "http://www.zimuku.la/search",
      // 设置字幕组的API
      "zimuzu": "http://www.zmz2019.com/search",
      // 设置字幕组获取字幕下载链接的API
      "zimuzu_subtitle_api_url": "http://got001.com/api/v1/static/subtitle/detail"
   }

支持的语言和文件格式:

字幕查找器语言文件格式
shooter[‘zh’, ‘en’][‘ass’, ‘srt’]
zimuku[‘zh_chs’, ‘zh_cht’, ‘en’, ‘zh_en’][‘ass’, ‘srt’]
zimuzu[‘zh_chs’, ‘zh_cht’, ‘en’, ‘zh_en’][‘ass’, ‘srt’]

语言代码:

代码含义
zh中文,简体或者繁体
en英文
zh_chs简体中文
zh_cht繁体中文
zh_en双语

配置文件

配置文件是JSON格式的,支持命令行中的所有选项。命令行中指定的选项优先级高于配置文件的。

配置文件中的key一一对应于命令行选项,例如-m,--method对应的key为method

示例:

{
   "exts": ["ass", "srt"],
   "method": ["shooter", "zimuzu", "zimuku"],
   "video_exts": [".mp4", ".mkv", ".iso"],
   "api_urls": {
      "zimuku": "http://www.zimuku.la/search",
      "zimuzu": "http://www.zmz2019.com/search",
      "zimuzu_subtitle_api_url": "http://got001.com/api/v1/static/subtitle/detail"
   }
}

本镜像的一些特点

  • 做了usermapping,使用你自己的账户权限来运行,这点对于群辉来说尤其重要
  • 支持选择执行检查完全部文件后是否后退出容器(默下载完成全部字幕后自动退出容器)
  • 镜像体积巨大200M,无法继续压缩镜像体积
  • base images使用ubuntu cloud (仅20M),alpine下缺少部分库

Architecture

只有x86-64版,arm64版编译失败,可能有些库没有

ArchitectureTag
x86-64latest

Changelogs

2020/04/11

  1、去掉cron,改用sleep,降低使用难度,防止cron失效。现在设置更简单,env里设置`TASK`时间即可  
  2、 `s 为秒,m 为 分钟,h 为小时,d 为日数`,默认2小时执行一次任务,例`TASK=2h`

2020/04/10

  1、update subfinder 1.1.2
  2、根据作者的意见,删除指定语言参数,默认全部语言
  3、修复zimuzu解析问题
  4、增加了手动选择执行间隔选项,`/config/subfinder-cron`,cron表达式

2020/04/09

1、update subfinder 1.1.1
  2、更改执行计划为,打开容器后开始遍历媒体文件,遍历结束后休眠,之后每隔一小时遍历一次
  3、更改媒体挂载卷为``/media``

2020/03/05

1、first commit

Document

挂载路径

/config /media

《Docker SubFinder 自动刮削字幕器》
《Docker SubFinder 自动刮削字幕器》

关于群晖

群晖DSM权限设置

群晖用户请使用你当前的用户SSH进系统,输入 id 你的用户id 获取到你的UID和GID并输入进去

《Docker SubFinder 自动刮削字幕器》
《Docker SubFinder 自动刮削字幕器》
《Docker SubFinder 自动刮削字幕器》

权限管理设置

《Docker SubFinder 自动刮削字幕器》

对你的docker配置文件夹的根目录进行如图操作,你的下载文件夹的根目录进行相似操作,去掉管理这个权限,只给写入,读取权限

Linux

输入 id 你的用户id 获取到你的UID和GID,替换命令中的PUID、PGID

执行命令

docker create \
  --name=subfinder \
  -e PUID=1026 \
  -e PGID=100 \
  -e TZ=Asia/Shanghai \
  -e TASK=2h \
  -v /path/to/appdata/config:/config \
  -v /path/to/libraries:/media \
  superng6/subfinder

docker-compose

  version: "3"
services:
  aria2:
    image: superng6/subfinder
    container_name: subfinder
    environment:
      - PUID=1026
      - PGID=100
      - TZ=Asia/Shanghai
      - TASK=2h
    volumes:
      - /path/to/appdata/config:/config
      - /path/to/libraries:/media

Preview

《Docker SubFinder 自动刮削字幕器》
《Docker SubFinder 自动刮削字幕器》
《Docker SubFinder 自动刮削字幕器》
原创声明
本文由 NG6 于2020年04月09日发表在sleele的博客
如未特殊声明,本站所有文章均为原创;你可以在保留作者及原文地址的情况下转载
转载请注明:Docker SubFinder 自动刮削字幕器 | sleele的博客
点赞
  1. JasonChio说道:

    按照教程配置好了docker和权限,但是仿佛没有扫描文件,开始之后直接下载完成,请问可能是什么原因呢

    1. NG6说道:

      文件名称不匹配,但是我觉得更可能是文件夹挂载错了

  2. 匿名说道:

    老哥,我想问下最后的日志是在哪里看的啊

    1. NG6说道:

      双击容器里有日志,最后一页就是末尾信息

  3. 匿名说道:

    直接日志本轮搜索已完成,就结束了

    1. NG6说道:

      没有搜索到本地文件?

  4. 墨非湮说道:

    挂在大目录,下面很多子目录好像无法识别?

    1. NG6说道:

      递归的,可以的,权限或者哪里错了

  5. 匿名说道:

    再请教一个问题,能否设置跳过已经下载过字幕的电影?昨天发现不少电影有重复下载的字幕,看了一下字幕文件的timestamp,确认是subfinder每天下载相同的字幕
    谢谢

    1. NG6说道:

      之前有试过,只对新文件进行查找下载,但是修改过的媒体文件无法被查找,所以就放弃了
      我这边看已经下载过的字幕是不会再下载的,你可以看一下文件修改和创建时间,是否有变更?

  6. roukey说道:

    有一个容器叫bazarr,是sonarr系列的,可以连接sonarr和radarr,然后下载字幕。try it

    1. NG6说道:

      用过,我觉得不太行,没有subfinder好使
      p2EWJP

  7. kittyzero说道:

    为什么还要设置aira2呀?
    突然蹦出来一个aira2有点懵

    1. NG6说道:

      之前的项目里粘过来的,描述权限设置的

  8. yang说道:

    您好,看起来我的docker虽然启动了。但是日志上显示并未找到字幕:40-config:exited 0;99-custom-scripts:exited 0.请问可以如何排查?

    1. NG6说道:

      这是正常日志,没有查到大概就是,1、没有匹配到 2、目录没挂载对,没有找到媒体文件,不管有没有下载成功都会有一大堆搜索日志

  9. somy1982说道:

    亲,如果media有几个文件夹,比如电影和TV分开存放咋设置?/media只能挂载一个

    1. NG6说道:

      再开一个容器,这也是docker的最佳实践,一个容器只干一件事,多占用几十兆内存而已。或者俩个影视目录都在一个大目录下,就挂载大目录

可以不需要填写邮箱(仅回复通知)和昵称直接评论,评论将在审核后通过(评论支持Markdown)

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据