Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 7ebcb8add4 | |||
| e18cc82792 | |||
| eb28cd0a0c | |||
| 2d688a6ed6 | |||
| e9aac52200 |
@ -45,7 +45,7 @@
|
||||
- 帧数必须为正整数(> 0)。
|
||||
- 若原始帧数 ≤ 指定帧数,则保留全部帧。
|
||||
|
||||
--s <速度>(可选)
|
||||
--speed <速度>(可选)
|
||||
- 调整 gif 图的速度。若为负数,则代表倒放
|
||||
|
||||
使用方式
|
||||
|
||||
39
konabot/plugins/bilibili_fetch/__init__.py
Normal file
39
konabot/plugins/bilibili_fetch/__init__.py
Normal file
@ -0,0 +1,39 @@
|
||||
import re
|
||||
|
||||
from nonebot import on_message
|
||||
from nonebot_plugin_alconna import Reference, Reply, UniMsg
|
||||
|
||||
from nonebot.adapters import Event
|
||||
|
||||
|
||||
matcher_fix = on_message()
|
||||
|
||||
pattern = (
|
||||
r"^(?:(?:av|cv)\d+|BV[a-zA-Z0-9]{10})|"
|
||||
r"(?:b23\.tv|bili(?:22|23|33|2233)\.cn|\.bilibili\.com|QQ小程序(?:&#93;|]|\])哔哩哔哩).{0,500}"
|
||||
)
|
||||
|
||||
|
||||
@matcher_fix.handle()
|
||||
async def _(msg: UniMsg, event: Event):
|
||||
to_search = msg.exclude(Reply, Reference).dump(json=True)
|
||||
to_search2 = msg.exclude(Reply, Reference).extract_plain_text()
|
||||
if not re.search(pattern, to_search) and not re.search(pattern, to_search2):
|
||||
return
|
||||
|
||||
from nonebot_plugin_analysis_bilibili import handle_analysis
|
||||
|
||||
await handle_analysis(event)
|
||||
|
||||
# b_url: str
|
||||
# b_page: str | None
|
||||
# b_time: str | None
|
||||
#
|
||||
# from nonebot_plugin_analysis_bilibili.analysis_bilibili import extract as bilibili_extract
|
||||
#
|
||||
# b_url, b_page, b_time = bilibili_extract(to_search)
|
||||
# if b_url is None:
|
||||
# return
|
||||
#
|
||||
# await matcher_fix.send(await UniMessage().text(b_url).export())
|
||||
|
||||
@ -1,25 +0,0 @@
|
||||
import re
|
||||
from loguru import logger
|
||||
from nonebot import on_message
|
||||
from nonebot_plugin_alconna import Reference, Reply, UniMsg
|
||||
|
||||
from nonebot.adapters import Event
|
||||
|
||||
|
||||
matcher_fix = on_message()
|
||||
|
||||
pattern = (
|
||||
r"^(?:(?:av|cv)\d+|BV[a-zA-Z0-9]{10})|"
|
||||
r"(?:b23\.tv|bili(?:22|23|33|2233)\.cn|\.bilibili\.com|QQ小程序(?:&#93;|]|\])哔哩哔哩).{0,500}"
|
||||
)
|
||||
|
||||
|
||||
@matcher_fix.handle()
|
||||
async def _(msg: UniMsg, event: Event):
|
||||
to_search = msg.exclude(Reply, Reference).dump(json=True)
|
||||
if not re.search(pattern, to_search):
|
||||
return
|
||||
logger.info("检测到有 Bilibili 相关的消息,直接进行一个调用")
|
||||
_module = __import__("nonebot_plugin_analysis_bilibili")
|
||||
await _module.handle_analysis(event)
|
||||
|
||||
@ -75,19 +75,41 @@ LAST_CHAR = ""
|
||||
|
||||
USER_NAME_CACHE = {} # 缓存用户名称,避免多次获取
|
||||
|
||||
REMAIN_PLAYING_TIMES = 1
|
||||
LAST_PLAY_DATE = ""
|
||||
|
||||
LOCK = False
|
||||
|
||||
ALL_BUFF_SCORE = 0 # 全体分数
|
||||
|
||||
import datetime
|
||||
|
||||
def be_able_to_play():
|
||||
global REMAIN_PLAYING_TIMES, LAST_PLAY_DATE
|
||||
if(LAST_PLAY_DATE != datetime.date.today()):
|
||||
LAST_PLAY_DATE = datetime.date.today()
|
||||
REMAIN_PLAYING_TIMES = 1
|
||||
if(REMAIN_PLAYING_TIMES > 0):
|
||||
REMAIN_PLAYING_TIMES -= 1
|
||||
return True
|
||||
return False
|
||||
|
||||
evt = on_alconna(Alconna(
|
||||
"我要玩成语接龙"
|
||||
), use_cmd_start=True, use_cmd_sep=False, skip_for_unmatch=True)
|
||||
|
||||
@evt.handle()
|
||||
async def _(event: BaseEvent):
|
||||
async def play_game(event: BaseEvent, force = False):
|
||||
global NOW_PLAYING, LAST_CHAR, INITED
|
||||
if not INITED:
|
||||
init_lexicon()
|
||||
INITED = True
|
||||
if NOW_PLAYING:
|
||||
await evt.send(await UniMessage().text("当前已有成语接龙游戏在进行中,请稍后再试!").export())
|
||||
return
|
||||
if not be_able_to_play() and not force:
|
||||
await evt.send(await UniMessage().text("玩玩玩,就知道玩,快去睡觉!").export())
|
||||
return
|
||||
if not INITED:
|
||||
init_lexicon()
|
||||
INITED = True
|
||||
NOW_PLAYING = True
|
||||
await evt.send(await UniMessage().text("你小子,还真有意思!\n好,成语接龙游戏开始!我说一个成语,请大家接下去!").export())
|
||||
# 选择一个随机成语
|
||||
@ -96,13 +118,22 @@ async def _(event: BaseEvent):
|
||||
# 发布成语
|
||||
await evt.send(await UniMessage().text(f"第一个成语:「{idiom}」,请接!").export())
|
||||
|
||||
evt = on_alconna(Alconna(
|
||||
"老子就是要玩成语接龙!!!"
|
||||
), use_cmd_start=True, use_cmd_sep=False, skip_for_unmatch=True)
|
||||
|
||||
@evt.handle()
|
||||
async def force_play_game(event: BaseEvent):
|
||||
await play_game(event, force=True)
|
||||
|
||||
|
||||
evt = on_alconna(Alconna(
|
||||
"不玩了"
|
||||
), use_cmd_start=True, use_cmd_sep=False, skip_for_unmatch=True)
|
||||
|
||||
@evt.handle()
|
||||
async def _(event: BaseEvent):
|
||||
global NOW_PLAYING, SCORE_BOARD, LAST_CHAR
|
||||
global NOW_PLAYING, SCORE_BOARD, LAST_CHAR, ALL_BUFF_SCORE
|
||||
if NOW_PLAYING:
|
||||
NOW_PLAYING = False
|
||||
# 发送好吧狗图片
|
||||
@ -117,7 +148,7 @@ async def _(event: BaseEvent):
|
||||
# 按分数排序,名字用 at 的方式
|
||||
sorted_score = sorted(SCORE_BOARD.items(), key=lambda x: x[1]["score"], reverse=True)
|
||||
for i, (user_id, info) in enumerate(sorted_score):
|
||||
result_text += f"{i+1}. " + UniMessage().at(user_id) + f": {info['score']} 分\n"
|
||||
result_text += f"{i+1}. " + UniMessage().at(user_id) + f": {info['score'] + ALL_BUFF_SCORE} 分\n"
|
||||
await evt.send(await result_text.export())
|
||||
# 重置分数板
|
||||
SCORE_BOARD = {}
|
||||
@ -132,12 +163,11 @@ evt = on_alconna(Alconna(
|
||||
|
||||
@evt.handle()
|
||||
async def _(event: BaseEvent):
|
||||
global NOW_PLAYING, LAST_CHAR
|
||||
global NOW_PLAYING, LAST_CHAR, ALL_BUFF_SCORE
|
||||
if not NOW_PLAYING:
|
||||
return
|
||||
await evt.send(await UniMessage().text("你们太菜了!全部扣100分!").export())
|
||||
for user_id in SCORE_BOARD:
|
||||
SCORE_BOARD[user_id]["score"] -= 100
|
||||
ALL_BUFF_SCORE -= 100
|
||||
# 选择下一个成语
|
||||
idiom = secrets.choice(ALL_IDIOMS)
|
||||
LAST_CHAR = idiom[-1]
|
||||
@ -148,14 +178,36 @@ evt = on_message()
|
||||
|
||||
@evt.handle()
|
||||
async def _(event: BaseEvent, msg: UniMsg):
|
||||
global NOW_PLAYING, LAST_CHAR, SCORE_BOARD
|
||||
global NOW_PLAYING, LAST_CHAR, LOCK
|
||||
if not NOW_PLAYING:
|
||||
return
|
||||
user_idiom = msg.extract_plain_text().strip()
|
||||
if(user_idiom[0] != LAST_CHAR):
|
||||
return
|
||||
if LOCK:
|
||||
return
|
||||
LOCK = True
|
||||
await handle_send_info(event, msg)
|
||||
LOCK = False
|
||||
|
||||
async def handle_send_info(event: BaseEvent, msg: UniMsg):
|
||||
global NOW_PLAYING, LAST_CHAR, SCORE_BOARD, ALL_BUFF_SCORE
|
||||
user_idiom = msg.extract_plain_text().strip()
|
||||
if(user_idiom not in ALL_IDIOMS and user_idiom not in ALL_WORDS):
|
||||
await evt.send(await UniMessage().text("接不上!这个不一样!").export())
|
||||
# 扣0.1分
|
||||
if isinstance(event, DiscordMessageEvent):
|
||||
user_id = str(event.author.id)
|
||||
user_name = str(event.author.name)
|
||||
else:
|
||||
user_id = str(event.get_user_id())
|
||||
user_name = str(event.get_user_id())
|
||||
if user_id not in SCORE_BOARD:
|
||||
SCORE_BOARD[user_id] = {
|
||||
"name": user_name,
|
||||
"score": 0
|
||||
}
|
||||
SCORE_BOARD[user_id]["score"] -= 0.1
|
||||
await evt.send(await UniMessage().at(user_id).text("接不上!这个不一样!你被扣了 0.1 分!").export())
|
||||
return
|
||||
# 成功接上
|
||||
if isinstance(event, DiscordMessageEvent):
|
||||
@ -172,6 +224,6 @@ async def _(event: BaseEvent, msg: UniMsg):
|
||||
}
|
||||
SCORE_BOARD[user_id]["score"] += 1
|
||||
# at 指定玩家
|
||||
await evt.send(await UniMessage().at(user_id).text(f"接对了!你有 {SCORE_BOARD[user_id]['score']} 分!").export())
|
||||
await evt.send(await UniMessage().at(user_id).text(f"接对了!你有 {SCORE_BOARD[user_id]['score'] + ALL_BUFF_SCORE} 分!").export())
|
||||
LAST_CHAR = user_idiom[-1]
|
||||
await evt.send(await UniMessage().text(f"下一个成语请以「{LAST_CHAR}」开头!").export())
|
||||
486
poetry.lock
generated
486
poetry.lock
generated
File diff suppressed because it is too large
Load Diff
@ -37,5 +37,10 @@ name = "pt-gitea-pypi"
|
||||
url = "https://gitea.service.jazzwhom.top/api/packages/Passthem/pypi/simple/"
|
||||
priority = "supplemental"
|
||||
|
||||
[[tool.poetry.source]]
|
||||
name = "mirrors"
|
||||
url = "https://pypi.tuna.tsinghua.edu.cn/simple/"
|
||||
priority = "primary"
|
||||
|
||||
[tool.poetry.dependencies]
|
||||
ptimeparse = {source = "pt-gitea-pypi"}
|
||||
|
||||
Reference in New Issue
Block a user