mirror of
https://github.com/EstrellaXD/Auto_Bangumi.git
synced 2026-04-14 02:20:53 +08:00
101 lines
3.0 KiB
Python
101 lines
3.0 KiB
Python
import re
|
|
import logging
|
|
import os.path as unix_path
|
|
import ntpath as win_path
|
|
|
|
from module.models import EpisodeFile, SubtitleFile
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
PLATFORM = "Unix"
|
|
|
|
RULES = [
|
|
r"(.*) - (\d{1,4}(?!\d|p)|\d{1,4}\.\d{1,2}(?!\d|p))(?:v\d{1,2})?(?: )?(?:END)?(.*)",
|
|
r"(.*)[\[\ E](\d{1,4}|\d{1,4}\.\d{1,2})(?:v\d{1,2})?(?: )?(?:END)?[\]\ ](.*)",
|
|
r"(.*)\[(?:第)?(\d*\.*\d*)[话集話](?:END)?\](.*)",
|
|
r"(.*)第?(\d*\.*\d*)[话話集](?:END)?(.*)",
|
|
r"(.*)(?:S\d{2})?EP?(\d+)(.*)",
|
|
]
|
|
|
|
SUBTITLE_LANG = {
|
|
"zh-tw": ["tc", "cht", "繁", "zh-tw"],
|
|
"zh": ["sc", "chs", "简", "zh"],
|
|
}
|
|
|
|
|
|
def split_path(torrent_path: str) -> str:
|
|
if PLATFORM == "Windows":
|
|
return win_path.split(torrent_path)[-1]
|
|
else:
|
|
return unix_path.split(torrent_path)[-1]
|
|
|
|
|
|
def get_group(group_and_title) -> tuple[str | None, str]:
|
|
n = re.split(r"[\[\]()【】()]", group_and_title)
|
|
while "" in n:
|
|
n.remove("")
|
|
if len(n) > 1:
|
|
if re.match(r"\d+", n[1]):
|
|
return None, group_and_title
|
|
return n[0], n[1]
|
|
else:
|
|
return None, n[0]
|
|
|
|
|
|
def get_season_and_title(season_and_title) -> tuple[str, int]:
|
|
title = re.sub(r"([Ss]|Season )\d{1,3}", "", season_and_title).strip()
|
|
try:
|
|
season = re.search(r"([Ss]|Season )(\d{1,3})", season_and_title, re.I).group(2)
|
|
except AttributeError:
|
|
season = 1
|
|
return title, int(season)
|
|
|
|
|
|
def get_subtitle_lang(subtitle_name: str) -> str:
|
|
for key, value in SUBTITLE_LANG.items():
|
|
for v in value:
|
|
if v in subtitle_name.lower():
|
|
return key
|
|
|
|
|
|
def torrent_parser(
|
|
torrent_path: str,
|
|
torrent_name: str | None = None,
|
|
season: int | None = None,
|
|
file_type: str = "media",
|
|
) -> EpisodeFile | SubtitleFile:
|
|
media_path = split_path(torrent_path)
|
|
for rule in RULES:
|
|
if torrent_name:
|
|
match_obj = re.match(rule, torrent_name, re.I)
|
|
else:
|
|
match_obj = re.match(rule, media_path, re.I)
|
|
if match_obj:
|
|
group, title = get_group(match_obj.group(1))
|
|
if not season:
|
|
title, season = get_season_and_title(title)
|
|
else:
|
|
title, _ = get_season_and_title(title)
|
|
episode = int(match_obj.group(2))
|
|
suffix = unix_path.splitext(torrent_path)[-1]
|
|
if file_type == "media":
|
|
return EpisodeFile(
|
|
media_path=torrent_path,
|
|
group=group,
|
|
title=title,
|
|
season=season,
|
|
episode=episode,
|
|
suffix=suffix,
|
|
)
|
|
elif file_type == "subtitle":
|
|
language = get_subtitle_lang(media_path)
|
|
return SubtitleFile(
|
|
media_path=torrent_path,
|
|
group=group,
|
|
title=title,
|
|
season=season,
|
|
language=language,
|
|
episode=episode,
|
|
suffix=suffix,
|
|
)
|