1 Star 1 Fork 0

Tippy/FollowAnime

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
AnimeEpisode.py 4.15 KB
一键复制 编辑 原始数据 按行查看 历史
import http.client
import xmlrpc.client
from time import sleep
import requests
from loguru import logger
from scrape import scrape
from utils import parse_num
class AnimeEpisode:
def __init__(self, name: str, season=1, episode=0, path: str = None, tm_id: str = None, language: str = "zh",
torrent_url: str = None, magnet: str = None, tmdb: object = None, bangumi_tag: str = None,
team: str = None):
"""
剧集
:param name: 动漫名称
:param season: 季度
:param episode: 集数
:param path: 本地存储路径
:param tm_id: TheMovieDB ID
:param language: 语言
:param torrent_url: 种子文件链接
:param magnet: 磁力链接
:param tmdb: TheMovieDB数据
:param bangumi_tag: 萌番组搜索时优先使用此tag,没有则用name搜索取首位
:param team: 字幕组tag
"""
self.name = name
self.season = season
self.episode = episode
self.path = path
self.tm_id = tm_id
self.language = language
self.torrent_url = torrent_url
self.magnet = magnet
self.tmdb = tmdb
self.bangumi_tag = bangumi_tag
self.team = team
self.format_name = "{} - S{}E{}".format(name, parse_num(season), parse_num(episode))
def set_anime_data(self, data):
if self.tmdb is None:
self.tmdb = {"tv": None}
self.tmdb["tv"] = data
def set_season_data(self, data):
self.tmdb["season"] = data
def set_episode_data(self, data):
self.tmdb["episode"] = data
self.format_name = "{} - S{}E{} - {}".format(self.name, parse_num(self.season), parse_num(self.episode),
data["name"])
def set_magnet(self, magnet):
self.magnet = magnet
def set_torrent(self, torrent_url):
self.torrent_url = torrent_url
def get_episode_name(self):
if self.tmdb and self.tmdb["episode"]:
return self.tmdb["episode"]["name"]
return ""
def downloading(self, client, gid):
"""
下载完成后修改文件名
:param client: aria2c
:param gid: aria2 返回的gid
:return:
"""
infoHash = client.tellStatus(gid=gid)["infoHash"]
new_gid = None
a = None
while new_gid is None:
actives = client.tellActive()
if len(actives) < 1:
new_gid = "null"
a = "null"
for active in actives:
# infoHash相同判断为同一个下载(会先下载种子在下载文件)
# 文件大小大于 1Mb 判断为文件,否则当作种子
if active["infoHash"] == infoHash and int(active["totalLength"]) > (1024 * 1000):
new_gid = active["gid"]
if new_gid is None:
sleep(5)
while not (new_gid is None) and a is None:
try:
status = client.tellStatus(gid=new_gid)
if status["status"] == "active" and status["seeder"] == "false":
logger.info(self.format_name + " 下载进度: " + str(
100 * int(status["completedLength"]) / int(status["totalLength"])) + "%")
sleep(10)
elif status["status"] == "active" and status["seeder"]=="true":
logger.info(self.format_name+"做种中...")
a = status
elif status["status"] == "complete":
# 暂停时status=="paused"
a = status
else:
a = "null"
except xmlrpc.client.Fault:
# GID xxx is not found
a = "null"
except http.client.CannotSendRequest or http.client.ResponseNotReady:
sleep(10)
if a == "null":
logger.info("%s 下载已停止, 请手动启动下载任务,下载完成后请手动修改文件名" % self.format_name)
else:
scrape(self, a["files"][0]["path"])
logger.info("下载完成:" + a["files"][0]["path"])
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Python
1
https://gitee.com/tippy_q/FollowAnime.git
git@gitee.com:tippy_q/FollowAnime.git
tippy_q
FollowAnime
FollowAnime
master

搜索帮助