mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-15 14:22:55 +08:00
modified: basic_plugins/admin_bot_manage/admin_config.py modified: basic_plugins/admin_bot_manage/custom_welcome_message.py modified: basic_plugins/admin_bot_manage/timing_task.py modified: basic_plugins/apscheduler/__init__.py modified: basic_plugins/ban/__init__.py modified: basic_plugins/ban/data_source.py modified: basic_plugins/chat_history/chat_message.py modified: basic_plugins/chat_history/chat_message_handle.py modified: basic_plugins/group_handle/__init__.py modified: basic_plugins/hooks/_utils.py modified: basic_plugins/hooks/ban_hook.py modified: basic_plugins/hooks/chkdsk_hook.py modified: basic_plugins/init_plugin_config/__init__.py deleted: basic_plugins/init_plugin_config/init_group_manager.py modified: basic_plugins/invite_manager/__init__.py new file: basic_plugins/invite_manager/utils.py modified: basic_plugins/nickname.py modified: basic_plugins/plugin_shop/__init__.py modified: basic_plugins/plugin_shop/data_source.py modified: basic_plugins/scripts.py modified: basic_plugins/shop/__init__.py modified: basic_plugins/shop/buy.py modified: basic_plugins/shop/gold.py modified: basic_plugins/shop/my_props/__init__.py deleted: basic_plugins/shop/reset_today_gold.py modified: basic_plugins/shop/shop_handle/__init__.py modified: basic_plugins/shop/shop_handle/data_source.py modified: basic_plugins/shop/use/__init__.py modified: basic_plugins/shop/use/data_source.py modified: basic_plugins/super_cmd/__init__.py modified: basic_plugins/super_cmd/bot_friend_group.py modified: basic_plugins/super_cmd/clear_data.py modified: basic_plugins/super_cmd/exec_sql.py modified: basic_plugins/super_cmd/manager_group.py modified: basic_plugins/super_cmd/reload_setting.py modified: basic_plugins/super_cmd/set_admin_permissions.py deleted: basic_plugins/super_cmd/super_task_switch.py modified: basic_plugins/super_cmd/update_friend_group_info.py modified: basic_plugins/super_help/__init__.py modified: basic_plugins/update_info.py modified: configs/config.py modified: configs/utils/__init__.py modified: models/bag_user.py modified: models/ban_user.py modified: models/chat_history.py modified: models/friend_user.py modified: models/goods_info.py modified: models/group_info.py modified: models/group_member_info.py modified: models/level_user.py modified: models/sign_group_user.py modified: models/user_shop_gold_log.py modified: plugins/aconfig/__init__.py modified: plugins/ai/__init__.py modified: plugins/ai/data_source.py modified: plugins/bilibili_sub/__init__.py modified: plugins/bilibili_sub/data_source.py modified: plugins/bilibili_sub/model.py modified: plugins/black_word/__init__.py modified: plugins/black_word/model.py modified: plugins/black_word/utils.py modified: plugins/bt/data_source.py modified: plugins/genshin/almanac/__init__.py modified: plugins/genshin/material_remind/__init__.py modified: plugins/genshin/query_user/_models/__init__.py modified: plugins/genshin/query_user/_utils/__init__.py modified: plugins/genshin/query_user/bind/__init__.py modified: plugins/genshin/query_user/genshin_sign/__init__.py modified: plugins/genshin/query_user/genshin_sign/data_source.py modified: plugins/genshin/query_user/genshin_sign/init_task.py modified: plugins/genshin/query_user/mihoyobbs_sign/__init__.py modified: plugins/genshin/query_user/query_memo/__init__.py modified: plugins/genshin/query_user/query_memo/data_source.py modified: plugins/genshin/query_user/query_role/__init__.py modified: plugins/genshin/query_user/query_role/data_source.py modified: plugins/genshin/query_user/reset_today_query_user_data/__init__.py modified: plugins/genshin/query_user/resin_remind/__init__.py modified: plugins/genshin/query_user/resin_remind/init_task.py modified: plugins/gold_redbag/model.py modified: plugins/image_management/send_image/__init__.py modified: plugins/my_info/__init__.py modified: plugins/open_cases/models/buff_prices.py modified: plugins/open_cases/models/open_cases_user.py modified: plugins/open_cases/open_cases_c.py modified: plugins/open_cases/utils.py modified: plugins/parse_bilibili_json.py modified: plugins/pid_search.py modified: plugins/pix_gallery/__init__.py modified: plugins/pix_gallery/_data_source.py modified: plugins/pix_gallery/_model/omega_pixiv_illusts.py modified: plugins/pix_gallery/_model/pixiv.py modified: plugins/pix_gallery/_model/pixiv_keyword_user.py modified: plugins/pix_gallery/pix_add_keyword.py modified: plugins/pix_gallery/pix_pass_del_keyword.py modified: plugins/pix_gallery/pix_show_info.py modified: plugins/pix_gallery/pix_update.py modified: plugins/pixiv_rank_search/data_source.py modified: plugins/poke/__init__.py modified: plugins/russian/__init__.py modified: plugins/russian/data_source.py modified: plugins/russian/model.py modified: plugins/send_dinggong_voice/__init__.py modified: plugins/send_setu_/_model.py modified: plugins/send_setu_/send_setu/__init__.py modified: plugins/send_setu_/send_setu/data_source.py modified: plugins/send_setu_/update_setu/data_source.py modified: plugins/sign_in/goods_register.py modified: plugins/sign_in/group_user_checkin.py modified: plugins/sign_in/random_event.py modified: plugins/sign_in/utils.py modified: plugins/statistics/_model.py modified: plugins/statistics/statistics_handle.py modified: plugins/statistics/statistics_hook.py modified: plugins/update_picture.py modified: plugins/web_ui/api/request.py modified: plugins/word_bank/_model.py deleted: plugins/word_bank/_old_model.py modified: plugins/word_bank/_rule.py modified: plugins/word_bank/word_handle.py modified: plugins/word_clouds/data_source.py modified: resources/image/sign/sign_res/bar.png modified: resources/image/sign/sign_res/bar_white.png modified: services/db_context.py modified: services/log.py modified: utils/browser.py modified: utils/data_utils.py modified: utils/depends/__init__.py modified: utils/http_utils.py modified: utils/image_utils.py modified: utils/manager/admin_manager.py modified: utils/message_builder.py modified: utils/utils.py
130 lines
4.1 KiB
Python
130 lines
4.1 KiB
Python
import asyncio
|
||
import os
|
||
import random
|
||
import re
|
||
from io import BytesIO
|
||
from typing import List
|
||
|
||
import jieba
|
||
import jieba.analyse
|
||
import matplotlib.pyplot as plt
|
||
import numpy as np
|
||
from emoji import replace_emoji # type: ignore
|
||
from PIL import Image as IMG
|
||
from wordcloud import ImageColorGenerator, WordCloud
|
||
|
||
from configs.config import Config
|
||
from configs.path_config import FONT_PATH, IMAGE_PATH
|
||
from models.chat_history import ChatHistory
|
||
from services import logger
|
||
from utils.http_utils import AsyncHttpx
|
||
|
||
|
||
async def pre_precess(msg: List[str], config) -> str:
|
||
return await asyncio.get_event_loop().run_in_executor(
|
||
None, _pre_precess, msg, config
|
||
)
|
||
|
||
|
||
def _pre_precess(msg: List[str], config) -> str:
|
||
"""对消息进行预处理"""
|
||
# 过滤掉命令
|
||
command_start = tuple([i for i in config.command_start if i])
|
||
msg = " ".join([m for m in msg if not m.startswith(command_start)])
|
||
|
||
# 去除网址
|
||
msg = re.sub(r"https?://[\w/:%#\$&\?\(\)~\.=\+\-]+", "", msg)
|
||
|
||
# 去除 \u200b
|
||
msg = re.sub(r"[\u200b]", "", msg)
|
||
|
||
# 去除cq码
|
||
msg = re.sub(r"\[CQ:.*?]", "", msg)
|
||
|
||
# 去除[]
|
||
msg = re.sub("[	(1|3);]", "", msg)
|
||
|
||
# 去除 emoji
|
||
# https://github.com/carpedm20/emoji
|
||
msg = replace_emoji(msg)
|
||
return msg
|
||
|
||
|
||
async def draw_word_cloud(messages, config):
|
||
wordcloud_dir = IMAGE_PATH / "wordcloud"
|
||
wordcloud_dir.mkdir(exist_ok=True, parents=True)
|
||
# 默认用真寻图片
|
||
zx_logo_path = wordcloud_dir / "default.png"
|
||
wordcloud_ttf = FONT_PATH / "STKAITI.TTF"
|
||
if not os.listdir(wordcloud_dir):
|
||
url = "https://ghproxy.com/https://raw.githubusercontent.com/HibiKier/zhenxun_bot/main/resources/image/wordcloud/default.png"
|
||
try:
|
||
await AsyncHttpx.download_file(url, zx_logo_path)
|
||
except Exception as e:
|
||
logger.error(f"词云图片资源下载发生错误 {type(e)}:{e}")
|
||
return False
|
||
if not wordcloud_ttf.exists():
|
||
ttf_url = "https://ghproxy.com/https://raw.githubusercontent.com/HibiKier/zhenxun_bot/main/resources/font/STKAITI.TTF"
|
||
try:
|
||
await AsyncHttpx.download_file(ttf_url, wordcloud_ttf)
|
||
except Exception as e:
|
||
logger.error(f"词云字体资源下载发生错误 {type(e)}:{e}")
|
||
return False
|
||
|
||
topK = min(int(len(messages)), 100000)
|
||
read_name = jieba.analyse.extract_tags(
|
||
await pre_precess(messages, config), topK=topK, withWeight=True, allowPOS=()
|
||
)
|
||
name = []
|
||
value = []
|
||
for t in read_name:
|
||
name.append(t[0])
|
||
value.append(t[1])
|
||
for i in range(len(name)):
|
||
name[i] = str(name[i])
|
||
dic = dict(zip(name, value))
|
||
if Config.get_config("word_clouds", "WORD_CLOUDS_TEMPLATE") == 1:
|
||
|
||
def random_pic(base_path: str) -> str:
|
||
path_dir = os.listdir(base_path)
|
||
path = random.sample(path_dir, 1)[0]
|
||
return str(base_path) + "/" + str(path)
|
||
|
||
mask = np.array(IMG.open(random_pic(wordcloud_dir)))
|
||
wc = WordCloud(
|
||
font_path=f"{wordcloud_ttf}",
|
||
background_color="white",
|
||
max_font_size=100,
|
||
width=1920,
|
||
height=1080,
|
||
mask=mask,
|
||
)
|
||
wc.generate_from_frequencies(dic)
|
||
image_colors = ImageColorGenerator(mask, default_color=(255, 255, 255))
|
||
wc.recolor(color_func=image_colors)
|
||
plt.imshow(wc.recolor(color_func=image_colors), interpolation="bilinear")
|
||
plt.axis("off")
|
||
else:
|
||
wc = WordCloud(
|
||
font_path=str(wordcloud_ttf),
|
||
width=1920,
|
||
height=1200,
|
||
background_color="black",
|
||
)
|
||
wc.generate_from_frequencies(dic)
|
||
bytes_io = BytesIO()
|
||
img = wc.to_image()
|
||
img.save(bytes_io, format="PNG")
|
||
return bytes_io.getvalue()
|
||
|
||
|
||
async def get_list_msg(user_id, group_id, days):
|
||
messages_list = await ChatHistory().get_message(
|
||
uid=user_id, gid=group_id, type_="group", days=days
|
||
)
|
||
if messages_list:
|
||
messages = [i.text for i in messages_list]
|
||
return messages
|
||
else:
|
||
return False
|