mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-15 14:22:55 +08:00
48 lines
1.8 KiB
Python
48 lines
1.8 KiB
Python
|
|
import time
|
|||
|
|
|
|||
|
|
from zhenxun.services.log import logger
|
|||
|
|
from zhenxun.utils.http_utils import AsyncHttpx
|
|||
|
|
|
|||
|
|
|
|||
|
|
async def get_anime(anime: str) -> str:
|
|||
|
|
s_time = time.time()
|
|||
|
|
url = "https://api.trace.moe/search?anilistInfo&url={}".format(anime)
|
|||
|
|
logger.debug("[info]Now starting get the {}".format(url))
|
|||
|
|
try:
|
|||
|
|
anime_json = (await AsyncHttpx.get(url)).json()
|
|||
|
|
if not anime_json["error"]:
|
|||
|
|
if anime_json == "Error reading imagenull":
|
|||
|
|
return "图像源错误,注意必须是静态图片哦"
|
|||
|
|
repass = ""
|
|||
|
|
# 拿到动漫 中文名
|
|||
|
|
for anime in anime_json["result"][:5]:
|
|||
|
|
synonyms = anime["anilist"]["synonyms"]
|
|||
|
|
for x in synonyms:
|
|||
|
|
_count_ch = 0
|
|||
|
|
for word in x:
|
|||
|
|
if "\u4e00" <= word <= "\u9fff":
|
|||
|
|
_count_ch += 1
|
|||
|
|
if _count_ch > 3:
|
|||
|
|
anime_name = x
|
|||
|
|
break
|
|||
|
|
else:
|
|||
|
|
anime_name = anime["anilist"]["title"]["native"]
|
|||
|
|
episode = anime["episode"]
|
|||
|
|
from_ = int(anime["from"])
|
|||
|
|
m, s = divmod(from_, 60)
|
|||
|
|
similarity = anime["similarity"]
|
|||
|
|
putline = "[ {} ][{}][{}:{}] 相似度:{:.2%}".format(
|
|||
|
|
anime_name,
|
|||
|
|
episode if episode else "?",
|
|||
|
|
m,
|
|||
|
|
s,
|
|||
|
|
similarity,
|
|||
|
|
)
|
|||
|
|
repass += putline + "\n"
|
|||
|
|
return f"耗时 {int(time.time() - s_time)} 秒\n" + repass[:-1]
|
|||
|
|
else:
|
|||
|
|
return f'访问错误 error:{anime_json["error"]}'
|
|||
|
|
except Exception as e:
|
|||
|
|
logger.error(f"识番发生错误", e=e)
|
|||
|
|
return "发生了奇怪的错误,那就没办法了,再试一次?"
|