mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-15 14:22:55 +08:00
148 lines
5.3 KiB
Python
148 lines
5.3 KiB
Python
from utils.message_builder import image, at, face
|
|
from typing import Tuple
|
|
from ._rule import check
|
|
from .model import WordBank
|
|
from configs.path_config import DATA_PATH
|
|
from nonebot.adapters.onebot.v11 import GroupMessageEvent
|
|
from utils.utils import get_message_at, get_message_img, change_img_md5
|
|
from nonebot import on_message
|
|
from models.group_member_info import GroupInfoUser
|
|
from utils.utils import get_message_img_file, is_number
|
|
import re
|
|
|
|
__zx_plugin_name__ = "词库问答回复操作 [Hidden]"
|
|
|
|
data_dir = DATA_PATH / "word_bank"
|
|
data_dir.mkdir(parents=True, exist_ok=True)
|
|
|
|
message_handle = on_message(priority=6, block=True, rule=check)
|
|
|
|
|
|
@message_handle.handle()
|
|
async def _(event: GroupMessageEvent):
|
|
msg = event.raw_message
|
|
list_img = get_message_img_file(event.json())
|
|
if list_img:
|
|
for img_file in list_img:
|
|
strinfo = re.compile(f"{img_file},.*?]")
|
|
msg = strinfo.sub(f'{img_file}]', msg)
|
|
strinfo_face = re.compile(f",type=sticker]")
|
|
msg = strinfo_face.sub(f']', msg)
|
|
q = await WordBank.check(event.group_id, msg, )
|
|
await message_handle.send(await get_one_answer(event, q.format, q.answer))
|
|
|
|
|
|
# 处理单条回答
|
|
async def get_one_answer(event, format: str, _answer: str, all: bool = True) -> str:
|
|
path = data_dir / f"{event.group_id}"
|
|
placeholder_list = (
|
|
[
|
|
(x.split("<_s>")[0], x.split("<_s>")[1])
|
|
for x in format.split("<format>")[:-1]
|
|
]
|
|
if format
|
|
else []
|
|
)
|
|
answer = ""
|
|
_a = _answer
|
|
if not placeholder_list:
|
|
answer = _a
|
|
return answer
|
|
else:
|
|
for idx, placeholder in placeholder_list:
|
|
if placeholder.endswith("jpg"):
|
|
change_img_md5(path / placeholder)
|
|
answer += _a[: _a.find(f"[__placeholder_{idx}]")] + image(
|
|
path / placeholder
|
|
)
|
|
else:
|
|
if all:
|
|
answer += _a[: _a.find(f"[__placeholder_{idx}]")] + at(int(placeholder))
|
|
else:
|
|
q = await GroupInfoUser.get_member_info(
|
|
int(placeholder), event.group_id)
|
|
answer += _a[: _a.find(f"[__placeholder_{idx}]")] + "@" + q.user_name
|
|
_a = _a[_a.find(f"[__placeholder_{idx}]") + len(f"[__placeholder_{idx}]"):]
|
|
return answer + _a
|
|
|
|
|
|
# 处理单条问题
|
|
async def get_one_problem(event, problem: str, ) -> Tuple[str, str]:
|
|
strinfo = re.compile(f",subType=\d")
|
|
problem = strinfo.sub('', problem)
|
|
_problem = problem
|
|
_p = problem
|
|
problem = ''
|
|
for img in get_message_img(event.json()):
|
|
_x = img.split("?")[0]
|
|
r = re.search(rf"\[CQ:image,file=(.*),url={_x}.*?]", _p)
|
|
if r:
|
|
_problem = _problem.replace(
|
|
rf",url={img}",
|
|
f"",
|
|
)
|
|
problem += _p[: _p.find(f"[CQ:image,file={r.group(1)},url={img}]")] + image(img)
|
|
_p = _p[
|
|
_p.find(f"[CQ:image,file={r.group(1)},url={img}]") + len(f"[CQ:image,file={r.group(1)},url={img}]"):]
|
|
for at_ in get_message_at(event.json()):
|
|
r = re.search(rf"\[CQ:at,qq={at_}]", problem)
|
|
if r:
|
|
q = await GroupInfoUser.get_member_info(
|
|
int(at_), event.group_id)
|
|
problem += _p[: _p.find(f"[CQ:at,qq={at_}]")] + "@" + q.user_name
|
|
_p = _p[_p.find(f"[CQ:at,qq={at_}]") + len(f"[CQ:at,qq={at_}]"):]
|
|
return _problem, problem + _p
|
|
|
|
|
|
# 显示单条数据库问题
|
|
async def get_one_image_problem(event, problem: str) -> str:
|
|
path = data_dir / f"{event.group_id}" / "problem"
|
|
placeholder_list = []
|
|
idx = 0
|
|
img_list = re.findall(rf"\[CQ:image,file=(.*?)]", problem)
|
|
at_list = re.findall(rf"\[CQ:at,qq=(.*?)]", problem)
|
|
if img_list:
|
|
for img in img_list:
|
|
problem = problem.replace(f'[CQ:image,file={img}]', f'[__placeholder_{idx}]', 1)
|
|
placeholder_list.append([idx, img])
|
|
idx += 1
|
|
if at_list:
|
|
for ats in at_list:
|
|
problem = problem.replace(f'[CQ:at,qq={ats}]', f'[__placeholder_{idx}]', 1)
|
|
placeholder_list.append([idx, ats])
|
|
idx += 1
|
|
_p = problem
|
|
problem = ''
|
|
if not placeholder_list:
|
|
problem = _p
|
|
return problem
|
|
else:
|
|
for idx, placeholder in placeholder_list:
|
|
if is_number(placeholder):
|
|
q = await GroupInfoUser.get_member_info(
|
|
int(placeholder), event.group_id)
|
|
problem += _p[: _p.find(f"[__placeholder_{idx}]")] + "@" + q.user_name
|
|
else:
|
|
problem += _p[: _p.find(f"[__placeholder_{idx}]")] + image(
|
|
path / f"{placeholder}.jpg"
|
|
)
|
|
_p = _p[_p.find(f"[__placeholder_{idx}]") + len(f"[__placeholder_{idx}]"):]
|
|
|
|
return problem + _p
|
|
|
|
|
|
# 替换cq码
|
|
async def replace_cq(group_id, msg: str, is_face: bool = True) -> str:
|
|
strinfo_img = re.compile(f"\[CQ:image.*?]")
|
|
msg = strinfo_img.sub('[图片]', msg)
|
|
at_list = re.findall(rf"\[CQ:at,qq=(.*?)]", msg)
|
|
if at_list:
|
|
for ats in at_list:
|
|
q = await GroupInfoUser.get_member_info(
|
|
int(ats), group_id)
|
|
msg = msg.replace(f'[CQ:at,qq={ats}]', "@" + q.user_name)
|
|
if is_face:
|
|
strinfo_face = re.compile(f"\[CQ:face,id=.*?]")
|
|
msg = strinfo_face.sub('[表情]', msg)
|
|
return msg
|