From 300a0d4129cc97a673ad9036dbd33c16c82a4f2c Mon Sep 17 00:00:00 2001 From: Ark-Hakobune <752780039@qq.com> Date: Mon, 17 Mar 2025 22:51:21 +0800 Subject: [PATCH] =?UTF-8?q?=E9=A2=9C=E6=96=87=E5=AD=97=E5=88=86=E5=89=B2?= =?UTF-8?q?=E9=97=AE=E9=A2=98=E4=BF=AE=E6=AD=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- MaiLauncher.bat | 1272 ++++++++++++++++++------------------- src/plugins/chat/utils.py | 56 +- 2 files changed, 691 insertions(+), 637 deletions(-) diff --git a/MaiLauncher.bat b/MaiLauncher.bat index 7b876bd37..766bfbfb5 100644 --- a/MaiLauncher.bat +++ b/MaiLauncher.bat @@ -1,636 +1,636 @@ -@echo off -@setlocal enabledelayedexpansion -@chcp 936 - -@REM 设置版本号 -set "VERSION=1.0" - -title 麦麦Bot控制台 v%VERSION% - -@REM 设置Python和Git环境变量 -set "_root=%~dp0" -set "_root=%_root:~0,-1%" -cd "%_root%" - - -:search_python -cls -if exist "%_root%\python" ( - set "PYTHON_HOME=%_root%\python" -) else if exist "%_root%\venv" ( - call "%_root%\venv\Scripts\activate.bat" - set "PYTHON_HOME=%_root%\venv\Scripts" -) else ( - echo 正在自动查找Python解释器... - - where python >nul 2>&1 - if %errorlevel% equ 0 ( - for /f "delims=" %%i in ('where python') do ( - echo %%i | findstr /i /c:"!LocalAppData!\Microsoft\WindowsApps\python.exe" >nul - if errorlevel 1 ( - echo 找到Python解释器:%%i - set "py_path=%%i" - goto :validate_python - ) - ) - ) - set "search_paths=%ProgramFiles%\Git*;!LocalAppData!\Programs\Python\Python*" - for /d %%d in (!search_paths!) do ( - if exist "%%d\python.exe" ( - set "py_path=%%d\python.exe" - goto :validate_python - ) - ) - echo 没有找到Python解释器,要安装吗? - set /p pyinstall_confirm="继续?(Y/n): " - if /i "!pyinstall_confirm!"=="Y" ( - cls - echo 正在安装Python... - winget install --id Python.Python.3.13 -e --accept-package-agreements --accept-source-agreements - if %errorlevel% neq 0 ( - echo 安装失败,请手动安装Python - start https://www.python.org/downloads/ - exit /b - ) - echo 安装完成,正在验证Python... - goto search_python - - ) else ( - echo 取消安装Python,按任意键退出... - pause >nul - exit /b - ) - - echo 错误:未找到可用的Python解释器! - exit /b 1 - - :validate_python - "!py_path!" --version >nul 2>&1 - if %errorlevel% neq 0 ( - echo 无效的Python解释器:%py_path% - exit /b 1 - ) - - :: 提取安装目录 - for %%i in ("%py_path%") do set "PYTHON_HOME=%%~dpi" - set "PYTHON_HOME=%PYTHON_HOME:~0,-1%" -) -if not exist "%PYTHON_HOME%\python.exe" ( - echo Python路径验证失败:%PYTHON_HOME% - echo 请检查Python安装路径中是否有python.exe文件 - exit /b 1 -) -echo 成功设置Python路径:%PYTHON_HOME% - - - -:search_git -cls -if exist "%_root%\tools\git\bin" ( - set "GIT_HOME=%_root%\tools\git\bin" -) else ( - echo 正在自动查找Git... - - where git >nul 2>&1 - if %errorlevel% equ 0 ( - for /f "delims=" %%i in ('where git') do ( - set "git_path=%%i" - goto :validate_git - ) - ) - echo 正在扫描常见安装路径... - set "search_paths=!ProgramFiles!\Git\cmd" - for /f "tokens=*" %%d in ("!search_paths!") do ( - if exist "%%d\git.exe" ( - set "git_path=%%d\git.exe" - goto :validate_git - ) - ) - echo 没有找到Git,要安装吗? - set /p confirm="继续?(Y/N): " - if /i "!confirm!"=="Y" ( - cls - echo 正在安装Git... - set "custom_url=https://ghfast.top/https://github.com/git-for-windows/git/releases/download/v2.48.1.windows.1/Git-2.48.1-64-bit.exe" - - set "download_path=%TEMP%\Git-Installer.exe" - - echo 正在下载Git安装包... - curl -L -o "!download_path!" "!custom_url!" - - if exist "!download_path!" ( - echo 下载成功,开始安装Git... - start /wait "" "!download_path!" /SILENT /NORESTART - ) else ( - echo 下载失败,请手动安装Git - start https://git-scm.com/download/win - exit /b - ) - - del "!download_path!" - echo 临时文件已清理。 - - echo 安装完成,正在验证Git... - where git >nul 2>&1 - if %errorlevel% equ 0 ( - for /f "delims=" %%i in ('where git') do ( - set "git_path=%%i" - goto :validate_git - ) - goto :search_git - - ) else ( - echo 安装完成,但未找到Git,请手动安装Git - start https://git-scm.com/download/win - exit /b - ) - - ) else ( - echo 取消安装Git,按任意键退出... - pause >nul - exit /b - ) - - echo 错误:未找到可用的Git! - exit /b 1 - - :validate_git - "%git_path%" --version >nul 2>&1 - if %errorlevel% neq 0 ( - echo 无效的Git:%git_path% - exit /b 1 - ) - - :: 提取安装目录 - for %%i in ("%git_path%") do set "GIT_HOME=%%~dpi" - set "GIT_HOME=%GIT_HOME:~0,-1%" -) - -:search_mongodb -cls -sc query | findstr /i "MongoDB" >nul -if !errorlevel! neq 0 ( - echo MongoDB服务未运行,是否尝试运行服务? - set /p confirm="是否启动?(Y/N): " - if /i "!confirm!"=="Y" ( - echo 正在尝试启动MongoDB服务... - powershell -Command "Start-Process -Verb RunAs cmd -ArgumentList '/c net start MongoDB'" - echo 正在等待MongoDB服务启动... - echo 按下任意键跳过等待... - timeout /t 30 >nul - sc query | findstr /i "MongoDB" >nul - if !errorlevel! neq 0 ( - echo MongoDB服务启动失败,可能是没有安装,要安装吗? - set /p install_confirm="继续安装?(Y/N): " - if /i "!install_confirm!"=="Y" ( - echo 正在安装MongoDB... - winget install --id MongoDB.Server -e --accept-package-agreements --accept-source-agreements - echo 安装完成,正在启动MongoDB服务... - net start MongoDB - if !errorlevel! neq 0 ( - echo 启动MongoDB服务失败,请手动启动 - exit /b - ) else ( - echo MongoDB服务已成功启动 - ) - ) else ( - echo 取消安装MongoDB,按任意键退出... - pause >nul - exit /b - ) - ) - ) else ( - echo "警告:MongoDB服务未运行,将导致MaiMBot无法访问数据库!" - ) -) else ( - echo MongoDB服务已运行 -) - -@REM set "GIT_HOME=%_root%\tools\git\bin" -set "PATH=%PYTHON_HOME%;%GIT_HOME%;%PATH%" - -:install_maim -if not exist "!_root!\bot.py" ( - cls - echo 你似乎没有安装麦麦Bot,要安装在当前目录吗? - set /p confirm="继续?(Y/N): " - if /i "!confirm!"=="Y" ( - echo 要使用Git代理下载吗? - set /p proxy_confirm="继续?(Y/N): " - if /i "!proxy_confirm!"=="Y" ( - echo 正在安装麦麦Bot... - git clone https://ghfast.top/https://github.com/SengokuCola/MaiMBot - ) else ( - echo 正在安装麦麦Bot... - git clone https://github.com/SengokuCola/MaiMBot - ) - xcopy /E /H /I MaiMBot . >nul 2>&1 - rmdir /s /q MaiMBot - git checkout main-fix - - echo 安装完成,正在安装依赖... - python -m pip config set global.index-url https://mirrors.aliyun.com/pypi/simple - python -m pip install virtualenv - python -m virtualenv venv - call venv\Scripts\activate.bat - python -m pip install -r requirements.txt - - echo 安装完成,要编辑配置文件吗? - set /p edit_confirm="继续?(Y/N): " - if /i "!edit_confirm!"=="Y" ( - goto config_menu - ) else ( - echo 取消编辑配置文件,按任意键返回主菜单... - ) - ) -) - - -@REM git获取当前分支名并保存在变量里 -for /f "delims=" %%b in ('git symbolic-ref --short HEAD 2^>nul') do ( - set "BRANCH=%%b" -) - -@REM 根据不同分支名给分支名字符串使用不同颜色 -echo 分支名: %BRANCH% -if "!BRANCH!"=="main" ( - set "BRANCH_COLOR=" -) else if "!BRANCH!"=="main-fix" ( - set "BRANCH_COLOR=" -@REM ) else if "%BRANCH%"=="stable-dev" ( -@REM set "BRANCH_COLOR=" -) else ( - set "BRANCH_COLOR=" -) - -@REM endlocal & set "BRANCH_COLOR=%BRANCH_COLOR%" - -:check_is_venv -echo 正在检查虚拟环境状态... -if exist "%_root%\config\no_venv" ( - echo 检测到no_venv,跳过虚拟环境检查 - goto menu -) - -:: 环境检测 -if defined VIRTUAL_ENV ( - goto menu -) - -echo ===================================== -echo 虚拟环境检测警告: -echo 当前使用系统Python路径:!PYTHON_HOME! -echo 未检测到激活的虚拟环境! - -:env_interaction -echo ===================================== -echo 请选择操作: -echo 1 - 创建并激活Venv虚拟环境 -echo 2 - 创建/激活Conda虚拟环境 -echo 3 - 临时跳过本次检查 -echo 4 - 永久跳过虚拟环境检查 -set /p choice="请输入选项(1-4): " - -if "!choice!"=="4" ( - echo 要永久跳过虚拟环境检查吗? - set /p no_venv_confirm="继续?(Y/N): ....." - if /i "!no_venv_confirm!"=="Y" ( - echo 1 > "%_root%\config\no_venv" - echo 已创建no_venv文件 - pause >nul - goto menu - ) else ( - echo 取消跳过虚拟环境检查,按任意键返回... - pause >nul - goto env_interaction - ) -) - -if "!choice!"=="3" ( - echo 警告:使用系统环境可能导致依赖冲突! - timeout /t 2 >nul - goto menu -) - -if "!choice!"=="2" goto handle_conda -if "!choice!"=="1" goto handle_venv - -echo 无效的输入,请输入1-4之间的数字 -timeout /t 2 >nul -goto env_interaction - -:handle_venv -python -m pip config set global.index-url https://mirrors.aliyun.com/pypi/simple -echo 正在初始化Venv环境... -python -m pip install virtualenv || ( - echo 安装环境失败,错误码:!errorlevel! - pause - goto env_interaction -) -echo 创建虚拟环境到:venv - python -m virtualenv venv || ( - echo 环境创建失败,错误码:!errorlevel! - pause - goto env_interaction -) - -call venv\Scripts\activate.bat -echo 已激活Venv环境 -echo 要安装依赖吗? -set /p install_confirm="继续?(Y/N): " -if /i "!install_confirm!"=="Y" ( - goto update_dependencies -) -goto menu - -:handle_conda -where conda >nul 2>&1 || ( - echo 未检测到conda,可能原因: - echo 1. 未安装Miniconda - echo 2. conda配置异常 - timeout /t 10 >nul - goto env_interaction -) - -:conda_menu -echo 请选择Conda操作: -echo 1 - 创建新环境 -echo 2 - 激活已有环境 -echo 3 - 返回上级菜单 -set /p choice="请输入选项(1-3): " - -if "!choice!"=="3" goto env_interaction -if "!choice!"=="2" goto activate_conda -if "!choice!"=="1" goto create_conda - -echo 无效的输入,请输入1-3之间的数字 -timeout /t 2 >nul -goto conda_menu - -:create_conda -set /p "CONDA_ENV=请输入新环境名称:" -if "!CONDA_ENV!"=="" ( - echo 环境名称不能为空! - goto create_conda -) -conda create -n !CONDA_ENV! python=3.13 -y || ( - echo 环境创建失败,错误码:!errorlevel! - timeout /t 10 >nul - goto conda_menu -) -goto activate_conda - -:activate_conda -set /p "CONDA_ENV=请输入要激活的环境名称:" -call conda activate !CONDA_ENV! || ( - echo 激活失败,可能原因: - echo 1. 环境不存在 - echo 2. conda配置异常 - pause - goto conda_menu -) -echo 成功激活conda环境:!CONDA_ENV! -echo 要安装依赖吗? -set /p install_confirm="继续?(Y/N): " -if /i "!install_confirm!"=="Y" ( - goto update_dependencies -) -:menu -@chcp 936 -cls -echo 麦麦Bot控制台 v%VERSION% 当前分支: %BRANCH_COLOR%%BRANCH% -echo 当前Python环境: !PYTHON_HOME! -echo ====================== -echo 1. 更新并启动麦麦Bot (默认) -echo 2. 直接启动麦麦Bot -echo 3. 启动麦麦配置界面 -echo 4. 打开麦麦神奇工具箱 -echo 5. 退出 -echo ====================== - -set /p choice="请输入选项数字 (1-5)并按下回车以选择: " - -if "!choice!"=="" set choice=1 - -if "!choice!"=="1" goto update_and_start -if "!choice!"=="2" goto start_bot -if "!choice!"=="3" goto config_menu -if "!choice!"=="4" goto tools_menu -if "!choice!"=="5" exit /b - -echo 无效的输入,请输入1-5之间的数字 -timeout /t 2 >nul -goto menu - -:config_menu -@chcp 936 -cls -if not exist config/bot_config.toml ( - copy /Y "template\bot_config_template.toml" "config\bot_config.toml" - -) -if not exist .env.prod ( - copy /Y "template\.env.prod" ".env.prod" -) - -start python webui.py - -goto menu - - -:tools_menu -@chcp 936 -cls -echo 麦麦时尚工具箱 当前分支: %BRANCH_COLOR%%BRANCH% -echo ====================== -echo 1. 更新依赖 -echo 2. 切换分支 -echo 3. 重置当前分支 -echo 4. 更新配置文件 -echo 5. 学习新的知识库 -echo 6. 打开知识库文件夹 -echo 7. 返回主菜单 -echo ====================== - -set /p choice="请输入选项数字: " -if "!choice!"=="1" goto update_dependencies -if "!choice!"=="2" goto switch_branch -if "!choice!"=="3" goto reset_branch -if "!choice!"=="4" goto update_config -if "!choice!"=="5" goto learn_new_knowledge -if "!choice!"=="6" goto open_knowledge_folder -if "!choice!"=="7" goto menu - -echo 无效的输入,请输入1-6之间的数字 -timeout /t 2 >nul -goto tools_menu - -:update_dependencies -cls -echo 正在更新依赖... -python -m pip config set global.index-url https://mirrors.aliyun.com/pypi/simple -python.exe -m pip install -r requirements.txt - -echo 依赖更新完成,按任意键返回工具箱菜单... -pause -goto tools_menu - -:switch_branch -cls -echo 正在切换分支... -echo 当前分支: %BRANCH% -@REM echo 可用分支: main, debug, stable-dev -echo 1. 切换到main -echo 2. 切换到main-fix -echo 请输入要切换到的分支: -set /p branch_name="分支名: " -if "%branch_name%"=="" set branch_name=main -if "%branch_name%"=="main" ( - set "BRANCH_COLOR=" -) else if "%branch_name%"=="main-fix" ( - set "BRANCH_COLOR=" -@REM ) else if "%branch_name%"=="stable-dev" ( -@REM set "BRANCH_COLOR=" -) else if "%branch_name%"=="1" ( - set "BRANCH_COLOR=" - set "branch_name=main" -) else if "%branch_name%"=="2" ( - set "BRANCH_COLOR=" - set "branch_name=main-fix" -) else ( - echo 无效的分支名, 请重新输入 - timeout /t 2 >nul - goto switch_branch -) - -echo 正在切换到分支 %branch_name%... -git checkout %branch_name% -echo 分支切换完成,当前分支: %BRANCH_COLOR%%branch_name% -set "BRANCH=%branch_name%" -echo 按任意键返回工具箱菜单... -pause >nul -goto tools_menu - - -:reset_branch -cls -echo 正在重置当前分支... -echo 当前分支: !BRANCH! -echo 确认要重置当前分支吗? -set /p confirm="继续?(Y/N): " -if /i "!confirm!"=="Y" ( - echo 正在重置当前分支... - git reset --hard !BRANCH! - echo 分支重置完成,按任意键返回工具箱菜单... -) else ( - echo 取消重置当前分支,按任意键返回工具箱菜单... -) -pause >nul -goto tools_menu - - -:update_config -cls -echo 正在更新配置文件... -echo 请确保已备份重要数据,继续将修改当前配置文件。 -echo 继续请按Y,取消请按任意键... -set /p confirm="继续?(Y/N): " -if /i "!confirm!"=="Y" ( - echo 正在更新配置文件... - python.exe config\auto_update.py - echo 配置文件更新完成,按任意键返回工具箱菜单... -) else ( - echo 取消更新配置文件,按任意键返回工具箱菜单... -) -pause >nul -goto tools_menu - -:learn_new_knowledge -cls -echo 正在学习新的知识库... -echo 请确保已备份重要数据,继续将修改当前知识库。 -echo 继续请按Y,取消请按任意键... -set /p confirm="继续?(Y/N): " -if /i "!confirm!"=="Y" ( - echo 正在学习新的知识库... - python.exe src\plugins\zhishi\knowledge_library.py - echo 学习完成,按任意键返回工具箱菜单... -) else ( - echo 取消学习新的知识库,按任意键返回工具箱菜单... -) -pause >nul -goto tools_menu - -:open_knowledge_folder -cls -echo 正在打开知识库文件夹... -if exist data\raw_info ( - start explorer data\raw_info -) else ( - echo 知识库文件夹不存在! - echo 正在创建文件夹... - mkdir data\raw_info - timeout /t 2 >nul -) -goto tools_menu - - -:update_and_start -cls -:retry_git_pull -git pull > temp.log 2>&1 -findstr /C:"detected dubious ownership" temp.log >nul -if %errorlevel% equ 0 ( - echo 检测到仓库权限问题,正在自动修复... - git config --global --add safe.directory "%cd%" - echo 已添加例外,正在重试git pull... - del temp.log - goto retry_git_pull -) -del temp.log -echo 正在更新依赖... -python -m pip config set global.index-url https://mirrors.aliyun.com/pypi/simple -python -m pip install -r requirements.txt && cls - -echo 当前代理设置: -echo HTTP_PROXY=%HTTP_PROXY% -echo HTTPS_PROXY=%HTTPS_PROXY% - -echo Disable Proxy... -set HTTP_PROXY= -set HTTPS_PROXY= -set no_proxy=0.0.0.0/32 - -REM chcp 65001 -python bot.py -echo. -echo Bot已停止运行,按任意键返回主菜单... -pause >nul -goto menu - -:start_bot -cls -echo 正在更新依赖... -python -m pip config set global.index-url https://mirrors.aliyun.com/pypi/simple -python -m pip install -r requirements.txt && cls - -echo 当前代理设置: -echo HTTP_PROXY=%HTTP_PROXY% -echo HTTPS_PROXY=%HTTPS_PROXY% - -echo Disable Proxy... -set HTTP_PROXY= -set HTTPS_PROXY= -set no_proxy=0.0.0.0/32 - -REM chcp 65001 -python bot.py -echo. -echo Bot已停止运行,按任意键返回主菜单... -pause >nul -goto menu - - -:open_dir -start explorer "%cd%" -goto menu +@echo off +@setlocal enabledelayedexpansion +@chcp 936 + +@REM 璁剧疆鐗堟湰鍙 +set "VERSION=1.0" + +title 楹﹂害Bot鎺у埗鍙 v%VERSION% + +@REM 璁剧疆Python鍜孏it鐜鍙橀噺 +set "_root=%~dp0" +set "_root=%_root:~0,-1%" +cd "%_root%" + + +:search_python +cls +if exist "%_root%\python" ( + set "PYTHON_HOME=%_root%\python" +) else if exist "%_root%\venv" ( + call "%_root%\venv\Scripts\activate.bat" + set "PYTHON_HOME=%_root%\venv\Scripts" +) else ( + echo 姝e湪鑷姩鏌ユ壘Python瑙i噴鍣... + + where python >nul 2>&1 + if %errorlevel% equ 0 ( + for /f "delims=" %%i in ('where python') do ( + echo %%i | findstr /i /c:"!LocalAppData!\Microsoft\WindowsApps\python.exe" >nul + if errorlevel 1 ( + echo 鎵惧埌Python瑙i噴鍣細%%i + set "py_path=%%i" + goto :validate_python + ) + ) + ) + set "search_paths=%ProgramFiles%\Git*;!LocalAppData!\Programs\Python\Python*" + for /d %%d in (!search_paths!) do ( + if exist "%%d\python.exe" ( + set "py_path=%%d\python.exe" + goto :validate_python + ) + ) + echo 娌℃湁鎵惧埌Python瑙i噴鍣,瑕佸畨瑁呭悧? + set /p pyinstall_confirm="缁х画锛(Y/n): " + if /i "!pyinstall_confirm!"=="Y" ( + cls + echo 姝e湪瀹夎Python... + winget install --id Python.Python.3.13 -e --accept-package-agreements --accept-source-agreements + if %errorlevel% neq 0 ( + echo 瀹夎澶辫触锛岃鎵嬪姩瀹夎Python + start https://www.python.org/downloads/ + exit /b + ) + echo 瀹夎瀹屾垚锛屾鍦ㄩ獙璇丳ython... + goto search_python + + ) else ( + echo 鍙栨秷瀹夎Python锛屾寜浠绘剰閿鍑... + pause >nul + exit /b + ) + + echo 閿欒锛氭湭鎵惧埌鍙敤鐨凱ython瑙i噴鍣紒 + exit /b 1 + + :validate_python + "!py_path!" --version >nul 2>&1 + if %errorlevel% neq 0 ( + echo 鏃犳晥鐨凱ython瑙i噴鍣細%py_path% + exit /b 1 + ) + + :: 鎻愬彇瀹夎鐩綍 + for %%i in ("%py_path%") do set "PYTHON_HOME=%%~dpi" + set "PYTHON_HOME=%PYTHON_HOME:~0,-1%" +) +if not exist "%PYTHON_HOME%\python.exe" ( + echo Python璺緞楠岃瘉澶辫触锛%PYTHON_HOME% + echo 璇锋鏌ython瀹夎璺緞涓槸鍚︽湁python.exe鏂囦欢 + exit /b 1 +) +echo 鎴愬姛璁剧疆Python璺緞锛%PYTHON_HOME% + + + +:search_git +cls +if exist "%_root%\tools\git\bin" ( + set "GIT_HOME=%_root%\tools\git\bin" +) else ( + echo 姝e湪鑷姩鏌ユ壘Git... + + where git >nul 2>&1 + if %errorlevel% equ 0 ( + for /f "delims=" %%i in ('where git') do ( + set "git_path=%%i" + goto :validate_git + ) + ) + echo 姝e湪鎵弿甯歌瀹夎璺緞... + set "search_paths=!ProgramFiles!\Git\cmd" + for /f "tokens=*" %%d in ("!search_paths!") do ( + if exist "%%d\git.exe" ( + set "git_path=%%d\git.exe" + goto :validate_git + ) + ) + echo 娌℃湁鎵惧埌Git锛岃瀹夎鍚楋紵 + set /p confirm="缁х画锛(Y/N): " + if /i "!confirm!"=="Y" ( + cls + echo 姝e湪瀹夎Git... + set "custom_url=https://ghfast.top/https://github.com/git-for-windows/git/releases/download/v2.48.1.windows.1/Git-2.48.1-64-bit.exe" + + set "download_path=%TEMP%\Git-Installer.exe" + + echo 姝e湪涓嬭浇Git瀹夎鍖... + curl -L -o "!download_path!" "!custom_url!" + + if exist "!download_path!" ( + echo 涓嬭浇鎴愬姛锛屽紑濮嬪畨瑁匞it... + start /wait "" "!download_path!" /SILENT /NORESTART + ) else ( + echo 涓嬭浇澶辫触锛岃鎵嬪姩瀹夎Git + start https://git-scm.com/download/win + exit /b + ) + + del "!download_path!" + echo 涓存椂鏂囦欢宸叉竻鐞嗐 + + echo 瀹夎瀹屾垚锛屾鍦ㄩ獙璇丟it... + where git >nul 2>&1 + if %errorlevel% equ 0 ( + for /f "delims=" %%i in ('where git') do ( + set "git_path=%%i" + goto :validate_git + ) + goto :search_git + + ) else ( + echo 瀹夎瀹屾垚锛屼絾鏈壘鍒癎it锛岃鎵嬪姩瀹夎Git + start https://git-scm.com/download/win + exit /b + ) + + ) else ( + echo 鍙栨秷瀹夎Git锛屾寜浠绘剰閿鍑... + pause >nul + exit /b + ) + + echo 閿欒锛氭湭鎵惧埌鍙敤鐨凣it锛 + exit /b 1 + + :validate_git + "%git_path%" --version >nul 2>&1 + if %errorlevel% neq 0 ( + echo 鏃犳晥鐨凣it锛%git_path% + exit /b 1 + ) + + :: 鎻愬彇瀹夎鐩綍 + for %%i in ("%git_path%") do set "GIT_HOME=%%~dpi" + set "GIT_HOME=%GIT_HOME:~0,-1%" +) + +:search_mongodb +cls +sc query | findstr /i "MongoDB" >nul +if !errorlevel! neq 0 ( + echo MongoDB鏈嶅姟鏈繍琛岋紝鏄惁灏濊瘯杩愯鏈嶅姟锛 + set /p confirm="鏄惁鍚姩锛(Y/N): " + if /i "!confirm!"=="Y" ( + echo 姝e湪灏濊瘯鍚姩MongoDB鏈嶅姟... + powershell -Command "Start-Process -Verb RunAs cmd -ArgumentList '/c net start MongoDB'" + echo 姝e湪绛夊緟MongoDB鏈嶅姟鍚姩... + echo 鎸変笅浠绘剰閿烦杩囩瓑寰... + timeout /t 30 >nul + sc query | findstr /i "MongoDB" >nul + if !errorlevel! neq 0 ( + echo MongoDB鏈嶅姟鍚姩澶辫触锛屽彲鑳芥槸娌℃湁瀹夎锛岃瀹夎鍚楋紵 + set /p install_confirm="缁х画瀹夎锛(Y/N): " + if /i "!install_confirm!"=="Y" ( + echo 姝e湪瀹夎MongoDB... + winget install --id MongoDB.Server -e --accept-package-agreements --accept-source-agreements + echo 瀹夎瀹屾垚锛屾鍦ㄥ惎鍔∕ongoDB鏈嶅姟... + net start MongoDB + if !errorlevel! neq 0 ( + echo 鍚姩MongoDB鏈嶅姟澶辫触锛岃鎵嬪姩鍚姩 + exit /b + ) else ( + echo MongoDB鏈嶅姟宸叉垚鍔熷惎鍔 + ) + ) else ( + echo 鍙栨秷瀹夎MongoDB锛屾寜浠绘剰閿鍑... + pause >nul + exit /b + ) + ) + ) else ( + echo "璀﹀憡锛歁ongoDB鏈嶅姟鏈繍琛岋紝灏嗗鑷碝aiMBot鏃犳硶璁块棶鏁版嵁搴擄紒" + ) +) else ( + echo MongoDB鏈嶅姟宸茶繍琛 +) + +@REM set "GIT_HOME=%_root%\tools\git\bin" +set "PATH=%PYTHON_HOME%;%GIT_HOME%;%PATH%" + +:install_maim +if not exist "!_root!\bot.py" ( + cls + echo 浣犱技涔庢病鏈夊畨瑁呴害楹ot锛岃瀹夎鍦ㄥ綋鍓嶇洰褰曞悧锛 + set /p confirm="缁х画锛(Y/N): " + if /i "!confirm!"=="Y" ( + echo 瑕佷娇鐢℅it浠g悊涓嬭浇鍚楋紵 + set /p proxy_confirm="缁х画锛(Y/N): " + if /i "!proxy_confirm!"=="Y" ( + echo 姝e湪瀹夎楹﹂害Bot... + git clone https://ghfast.top/https://github.com/SengokuCola/MaiMBot + ) else ( + echo 姝e湪瀹夎楹﹂害Bot... + git clone https://github.com/SengokuCola/MaiMBot + ) + xcopy /E /H /I MaiMBot . >nul 2>&1 + rmdir /s /q MaiMBot + git checkout main-fix + + echo 瀹夎瀹屾垚锛屾鍦ㄥ畨瑁呬緷璧... + python -m pip config set global.index-url https://mirrors.aliyun.com/pypi/simple + python -m pip install virtualenv + python -m virtualenv venv + call venv\Scripts\activate.bat + python -m pip install -r requirements.txt + + echo 瀹夎瀹屾垚锛岃缂栬緫閰嶇疆鏂囦欢鍚楋紵 + set /p edit_confirm="缁х画锛(Y/N): " + if /i "!edit_confirm!"=="Y" ( + goto config_menu + ) else ( + echo 鍙栨秷缂栬緫閰嶇疆鏂囦欢锛屾寜浠绘剰閿繑鍥炰富鑿滃崟... + ) + ) +) + + +@REM git鑾峰彇褰撳墠鍒嗘敮鍚嶅苟淇濆瓨鍦ㄥ彉閲忛噷 +for /f "delims=" %%b in ('git symbolic-ref --short HEAD 2^>nul') do ( + set "BRANCH=%%b" +) + +@REM 鏍规嵁涓嶅悓鍒嗘敮鍚嶇粰鍒嗘敮鍚嶅瓧绗︿覆浣跨敤涓嶅悓棰滆壊 +echo 鍒嗘敮鍚: %BRANCH% +if "!BRANCH!"=="main" ( + set "BRANCH_COLOR=" +) else if "!BRANCH!"=="main-fix" ( + set "BRANCH_COLOR=" +@REM ) else if "%BRANCH%"=="stable-dev" ( +@REM set "BRANCH_COLOR=" +) else ( + set "BRANCH_COLOR=" +) + +@REM endlocal & set "BRANCH_COLOR=%BRANCH_COLOR%" + +:check_is_venv +echo 姝e湪妫鏌ヨ櫄鎷熺幆澧冪姸鎬... +if exist "%_root%\config\no_venv" ( + echo 妫娴嬪埌no_venv,璺宠繃铏氭嫙鐜妫鏌 + goto menu +) + +:: 鐜妫娴 +if defined VIRTUAL_ENV ( + goto menu +) + +echo ===================================== +echo 铏氭嫙鐜妫娴嬭鍛婏細 +echo 褰撳墠浣跨敤绯荤粺Python璺緞锛!PYTHON_HOME! +echo 鏈娴嬪埌婵娲荤殑铏氭嫙鐜锛 + +:env_interaction +echo ===================================== +echo 璇烽夋嫨鎿嶄綔锛 +echo 1 - 鍒涘缓骞舵縺娲籚env铏氭嫙鐜 +echo 2 - 鍒涘缓/婵娲籆onda铏氭嫙鐜 +echo 3 - 涓存椂璺宠繃鏈妫鏌 +echo 4 - 姘镐箙璺宠繃铏氭嫙鐜妫鏌 +set /p choice="璇疯緭鍏ラ夐」(1-4): " + +if "!choice!"=="4" ( + echo 瑕佹案涔呰烦杩囪櫄鎷熺幆澧冩鏌ュ悧锛 + set /p no_venv_confirm="缁х画锛(Y/N): ....." + if /i "!no_venv_confirm!"=="Y" ( + echo 1 > "%_root%\config\no_venv" + echo 宸插垱寤簄o_venv鏂囦欢 + pause >nul + goto menu + ) else ( + echo 鍙栨秷璺宠繃铏氭嫙鐜妫鏌ワ紝鎸変换鎰忛敭杩斿洖... + pause >nul + goto env_interaction + ) +) + +if "!choice!"=="3" ( + echo 璀﹀憡锛氫娇鐢ㄧ郴缁熺幆澧冨彲鑳藉鑷翠緷璧栧啿绐侊紒 + timeout /t 2 >nul + goto menu +) + +if "!choice!"=="2" goto handle_conda +if "!choice!"=="1" goto handle_venv + +echo 鏃犳晥鐨勮緭鍏ワ紝璇疯緭鍏1-4涔嬮棿鐨勬暟瀛 +timeout /t 2 >nul +goto env_interaction + +:handle_venv +python -m pip config set global.index-url https://mirrors.aliyun.com/pypi/simple +echo 姝e湪鍒濆鍖朧env鐜... +python -m pip install virtualenv || ( + echo 瀹夎鐜澶辫触锛岄敊璇爜锛!errorlevel! + pause + goto env_interaction +) +echo 鍒涘缓铏氭嫙鐜鍒帮細venv + python -m virtualenv venv || ( + echo 鐜鍒涘缓澶辫触锛岄敊璇爜锛!errorlevel! + pause + goto env_interaction +) + +call venv\Scripts\activate.bat +echo 宸叉縺娲籚env鐜 +echo 瑕佸畨瑁呬緷璧栧悧锛 +set /p install_confirm="缁х画锛(Y/N): " +if /i "!install_confirm!"=="Y" ( + goto update_dependencies +) +goto menu + +:handle_conda +where conda >nul 2>&1 || ( + echo 鏈娴嬪埌conda锛屽彲鑳藉師鍥狅細 + echo 1. 鏈畨瑁匨iniconda + echo 2. conda閰嶇疆寮傚父 + timeout /t 10 >nul + goto env_interaction +) + +:conda_menu +echo 璇烽夋嫨Conda鎿嶄綔锛 +echo 1 - 鍒涘缓鏂扮幆澧 +echo 2 - 婵娲诲凡鏈夌幆澧 +echo 3 - 杩斿洖涓婄骇鑿滃崟 +set /p choice="璇疯緭鍏ラ夐」(1-3): " + +if "!choice!"=="3" goto env_interaction +if "!choice!"=="2" goto activate_conda +if "!choice!"=="1" goto create_conda + +echo 鏃犳晥鐨勮緭鍏ワ紝璇疯緭鍏1-3涔嬮棿鐨勬暟瀛 +timeout /t 2 >nul +goto conda_menu + +:create_conda +set /p "CONDA_ENV=璇疯緭鍏ユ柊鐜鍚嶇О锛" +if "!CONDA_ENV!"=="" ( + echo 鐜鍚嶇О涓嶈兘涓虹┖锛 + goto create_conda +) +conda create -n !CONDA_ENV! python=3.13 -y || ( + echo 鐜鍒涘缓澶辫触锛岄敊璇爜锛!errorlevel! + timeout /t 10 >nul + goto conda_menu +) +goto activate_conda + +:activate_conda +set /p "CONDA_ENV=璇疯緭鍏ヨ婵娲荤殑鐜鍚嶇О锛" +call conda activate !CONDA_ENV! || ( + echo 婵娲诲け璐ワ紝鍙兘鍘熷洜锛 + echo 1. 鐜涓嶅瓨鍦 + echo 2. conda閰嶇疆寮傚父 + pause + goto conda_menu +) +echo 鎴愬姛婵娲籧onda鐜锛!CONDA_ENV! +echo 瑕佸畨瑁呬緷璧栧悧锛 +set /p install_confirm="缁х画锛(Y/N): " +if /i "!install_confirm!"=="Y" ( + goto update_dependencies +) +:menu +@chcp 936 +cls +echo 楹﹂害Bot鎺у埗鍙 v%VERSION% 褰撳墠鍒嗘敮: %BRANCH_COLOR%%BRANCH% +echo 褰撳墠Python鐜: !PYTHON_HOME! +echo ====================== +echo 1. 鏇存柊骞跺惎鍔ㄩ害楹ot (榛樿) +echo 2. 鐩存帴鍚姩楹﹂害Bot +echo 3. 鍚姩楹﹂害閰嶇疆鐣岄潰 +echo 4. 鎵撳紑楹﹂害绁炲宸ュ叿绠 +echo 5. 閫鍑 +echo ====================== + +set /p choice="璇疯緭鍏ラ夐」鏁板瓧 (1-5)骞舵寜涓嬪洖杞︿互閫夋嫨: " + +if "!choice!"=="" set choice=1 + +if "!choice!"=="1" goto update_and_start +if "!choice!"=="2" goto start_bot +if "!choice!"=="3" goto config_menu +if "!choice!"=="4" goto tools_menu +if "!choice!"=="5" exit /b + +echo 鏃犳晥鐨勮緭鍏ワ紝璇疯緭鍏1-5涔嬮棿鐨勬暟瀛 +timeout /t 2 >nul +goto menu + +:config_menu +@chcp 936 +cls +if not exist config/bot_config.toml ( + copy /Y "template\bot_config_template.toml" "config\bot_config.toml" + +) +if not exist .env.prod ( + copy /Y "template\.env.prod" ".env.prod" +) + +start python webui.py + +goto menu + + +:tools_menu +@chcp 936 +cls +echo 楹﹂害鏃跺皻宸ュ叿绠 褰撳墠鍒嗘敮: %BRANCH_COLOR%%BRANCH% +echo ====================== +echo 1. 鏇存柊渚濊禆 +echo 2. 鍒囨崲鍒嗘敮 +echo 3. 閲嶇疆褰撳墠鍒嗘敮 +echo 4. 鏇存柊閰嶇疆鏂囦欢 +echo 5. 瀛︿範鏂扮殑鐭ヨ瘑搴 +echo 6. 鎵撳紑鐭ヨ瘑搴撴枃浠跺す +echo 7. 杩斿洖涓昏彍鍗 +echo ====================== + +set /p choice="璇疯緭鍏ラ夐」鏁板瓧: " +if "!choice!"=="1" goto update_dependencies +if "!choice!"=="2" goto switch_branch +if "!choice!"=="3" goto reset_branch +if "!choice!"=="4" goto update_config +if "!choice!"=="5" goto learn_new_knowledge +if "!choice!"=="6" goto open_knowledge_folder +if "!choice!"=="7" goto menu + +echo 鏃犳晥鐨勮緭鍏ワ紝璇疯緭鍏1-6涔嬮棿鐨勬暟瀛 +timeout /t 2 >nul +goto tools_menu + +:update_dependencies +cls +echo 姝e湪鏇存柊渚濊禆... +python -m pip config set global.index-url https://mirrors.aliyun.com/pypi/simple +python.exe -m pip install -r requirements.txt + +echo 渚濊禆鏇存柊瀹屾垚锛屾寜浠绘剰閿繑鍥炲伐鍏风鑿滃崟... +pause +goto tools_menu + +:switch_branch +cls +echo 姝e湪鍒囨崲鍒嗘敮... +echo 褰撳墠鍒嗘敮: %BRANCH% +@REM echo 鍙敤鍒嗘敮: main, debug, stable-dev +echo 1. 鍒囨崲鍒main +echo 2. 鍒囨崲鍒main-fix +echo 璇疯緭鍏ヨ鍒囨崲鍒扮殑鍒嗘敮: +set /p branch_name="鍒嗘敮鍚: " +if "%branch_name%"=="" set branch_name=main +if "%branch_name%"=="main" ( + set "BRANCH_COLOR=" +) else if "%branch_name%"=="main-fix" ( + set "BRANCH_COLOR=" +@REM ) else if "%branch_name%"=="stable-dev" ( +@REM set "BRANCH_COLOR=" +) else if "%branch_name%"=="1" ( + set "BRANCH_COLOR=" + set "branch_name=main" +) else if "%branch_name%"=="2" ( + set "BRANCH_COLOR=" + set "branch_name=main-fix" +) else ( + echo 鏃犳晥鐨勫垎鏀悕, 璇烽噸鏂拌緭鍏 + timeout /t 2 >nul + goto switch_branch +) + +echo 姝e湪鍒囨崲鍒板垎鏀 %branch_name%... +git checkout %branch_name% +echo 鍒嗘敮鍒囨崲瀹屾垚锛屽綋鍓嶅垎鏀: %BRANCH_COLOR%%branch_name% +set "BRANCH=%branch_name%" +echo 鎸変换鎰忛敭杩斿洖宸ュ叿绠辫彍鍗... +pause >nul +goto tools_menu + + +:reset_branch +cls +echo 姝e湪閲嶇疆褰撳墠鍒嗘敮... +echo 褰撳墠鍒嗘敮: !BRANCH! +echo 纭瑕侀噸缃綋鍓嶅垎鏀悧锛 +set /p confirm="缁х画锛(Y/N): " +if /i "!confirm!"=="Y" ( + echo 姝e湪閲嶇疆褰撳墠鍒嗘敮... + git reset --hard !BRANCH! + echo 鍒嗘敮閲嶇疆瀹屾垚锛屾寜浠绘剰閿繑鍥炲伐鍏风鑿滃崟... +) else ( + echo 鍙栨秷閲嶇疆褰撳墠鍒嗘敮锛屾寜浠绘剰閿繑鍥炲伐鍏风鑿滃崟... +) +pause >nul +goto tools_menu + + +:update_config +cls +echo 姝e湪鏇存柊閰嶇疆鏂囦欢... +echo 璇风‘淇濆凡澶囦唤閲嶈鏁版嵁锛岀户缁皢淇敼褰撳墠閰嶇疆鏂囦欢銆 +echo 缁х画璇锋寜Y锛屽彇娑堣鎸変换鎰忛敭... +set /p confirm="缁х画锛(Y/N): " +if /i "!confirm!"=="Y" ( + echo 姝e湪鏇存柊閰嶇疆鏂囦欢... + python.exe config\auto_update.py + echo 閰嶇疆鏂囦欢鏇存柊瀹屾垚锛屾寜浠绘剰閿繑鍥炲伐鍏风鑿滃崟... +) else ( + echo 鍙栨秷鏇存柊閰嶇疆鏂囦欢锛屾寜浠绘剰閿繑鍥炲伐鍏风鑿滃崟... +) +pause >nul +goto tools_menu + +:learn_new_knowledge +cls +echo 姝e湪瀛︿範鏂扮殑鐭ヨ瘑搴... +echo 璇风‘淇濆凡澶囦唤閲嶈鏁版嵁锛岀户缁皢淇敼褰撳墠鐭ヨ瘑搴撱 +echo 缁х画璇锋寜Y锛屽彇娑堣鎸変换鎰忛敭... +set /p confirm="缁х画锛(Y/N): " +if /i "!confirm!"=="Y" ( + echo 姝e湪瀛︿範鏂扮殑鐭ヨ瘑搴... + python.exe src\plugins\zhishi\knowledge_library.py + echo 瀛︿範瀹屾垚锛屾寜浠绘剰閿繑鍥炲伐鍏风鑿滃崟... +) else ( + echo 鍙栨秷瀛︿範鏂扮殑鐭ヨ瘑搴擄紝鎸変换鎰忛敭杩斿洖宸ュ叿绠辫彍鍗... +) +pause >nul +goto tools_menu + +:open_knowledge_folder +cls +echo 姝e湪鎵撳紑鐭ヨ瘑搴撴枃浠跺す... +if exist data\raw_info ( + start explorer data\raw_info +) else ( + echo 鐭ヨ瘑搴撴枃浠跺す涓嶅瓨鍦紒 + echo 姝e湪鍒涘缓鏂囦欢澶... + mkdir data\raw_info + timeout /t 2 >nul +) +goto tools_menu + + +:update_and_start +cls +:retry_git_pull +git pull > temp.log 2>&1 +findstr /C:"detected dubious ownership" temp.log >nul +if %errorlevel% equ 0 ( + echo 妫娴嬪埌浠撳簱鏉冮檺闂锛屾鍦ㄨ嚜鍔ㄤ慨澶... + git config --global --add safe.directory "%cd%" + echo 宸叉坊鍔犱緥澶栵紝姝e湪閲嶈瘯git pull... + del temp.log + goto retry_git_pull +) +del temp.log +echo 姝e湪鏇存柊渚濊禆... +python -m pip config set global.index-url https://mirrors.aliyun.com/pypi/simple +python -m pip install -r requirements.txt && cls + +echo 褰撳墠浠g悊璁剧疆: +echo HTTP_PROXY=%HTTP_PROXY% +echo HTTPS_PROXY=%HTTPS_PROXY% + +echo Disable Proxy... +set HTTP_PROXY= +set HTTPS_PROXY= +set no_proxy=0.0.0.0/32 + +REM chcp 65001 +python bot.py +echo. +echo Bot宸插仠姝㈣繍琛岋紝鎸変换鎰忛敭杩斿洖涓昏彍鍗... +pause >nul +goto menu + +:start_bot +cls +echo 姝e湪鏇存柊渚濊禆... +python -m pip config set global.index-url https://mirrors.aliyun.com/pypi/simple +python -m pip install -r requirements.txt && cls + +echo 褰撳墠浠g悊璁剧疆: +echo HTTP_PROXY=%HTTP_PROXY% +echo HTTPS_PROXY=%HTTPS_PROXY% + +echo Disable Proxy... +set HTTP_PROXY= +set HTTPS_PROXY= +set no_proxy=0.0.0.0/32 + +REM chcp 65001 +python bot.py +echo. +echo Bot宸插仠姝㈣繍琛岋紝鎸変换鎰忛敭杩斿洖涓昏彍鍗... +pause >nul +goto menu + + +:open_dir +start explorer "%cd%" +goto menu diff --git a/src/plugins/chat/utils.py b/src/plugins/chat/utils.py index 92eae1b32..b5615ebf8 100644 --- a/src/plugins/chat/utils.py +++ b/src/plugins/chat/utils.py @@ -1,6 +1,7 @@ import math import random import time +import re from collections import Counter from typing import Dict, List @@ -253,7 +254,7 @@ def split_into_sentences_w_remove_punctuation(text: str) -> List[str]: # 缁熶竴灏嗚嫳鏂囬楀彿杞崲涓轰腑鏂囬楀彿 text = text.replace(',', '锛') text = text.replace('\n', ' ') - + text, mapping = protect_kaomoji(text) # print(f"澶勭悊鍓嶇殑鏂囨湰: {text}") text_no_1 = '' @@ -292,6 +293,7 @@ def split_into_sentences_w_remove_punctuation(text: str) -> List[str]: current_sentence += ' ' + part new_sentences.append(current_sentence.strip()) sentences = [s for s in new_sentences if s] # 绉婚櫎绌哄瓧绗︿覆 + sentences = recover_kaomoji(sentences, mapping) # print(f"鍒嗗壊鍚庣殑鍙ュ瓙: {sentences}") sentences_done = [] @@ -446,3 +448,55 @@ def truncate_message(message: str, max_length=20) -> str: if len(message) > max_length: return message[:max_length] + "..." return message + + +def protect_kaomoji(sentence): + """" + 璇嗗埆骞朵繚鎶ゅ彞瀛愪腑鐨勯鏂囧瓧锛堝惈鎷彿涓庢棤鎷彿锛夛紝灏嗗叾鏇挎崲涓哄崰浣嶇锛 + 骞惰繑鍥炴浛鎹㈠悗鐨勫彞瀛愬拰鍗犱綅绗﹀埌棰滄枃瀛楃殑鏄犲皠琛ㄣ + Args: + sentence (str): 杈撳叆鐨勫師濮嬪彞瀛 + Returns: + tuple: (澶勭悊鍚庣殑鍙ュ瓙, {鍗犱綅绗: 棰滄枃瀛梷) + """ + kaomoji_pattern = re.compile( + r'(' + r'[\(\[锛堛怾' # 宸︽嫭鍙 + r'[^()\[\]锛堬級銆愩慮*?' # 闈炴嫭鍙峰瓧绗︼紙鎯版у尮閰嶏級 + r'[^\u4e00-\u9fa5a-zA-Z0-9\s]' # 闈炰腑鏂囥侀潪鑻辨枃銆侀潪鏁板瓧銆侀潪绌烘牸瀛楃锛堝繀椤诲寘鍚嚦灏戜竴涓級 + r'[^()\[\]锛堬級銆愩慮*?' # 闈炴嫭鍙峰瓧绗︼紙鎯版у尮閰嶏級 + r'[\)\]锛夈慮' # 鍙虫嫭鍙 + r')' + r'|' + r'(' + r'[鈻尖柦銉会触蠅锝ワ箯^><鈮р墻锟o絸麓鈭銉斝达缚锕銇革健锞熲暐鈺暟锔讹腹鈥⑩亜]{2,15}' + r')' + ) + + kaomoji_matches = kaomoji_pattern.findall(sentence) + placeholder_to_kaomoji = {} + + for idx, match in enumerate(kaomoji_matches): + kaomoji = match[0] if match[0] else match[1] + placeholder = f'__KAOMOJI_{idx}__' + sentence = sentence.replace(kaomoji, placeholder, 1) + placeholder_to_kaomoji[placeholder] = kaomoji + + return sentence, placeholder_to_kaomoji + + +def recover_kaomoji(sentences, placeholder_to_kaomoji): + """ + 鏍规嵁鏄犲皠琛ㄦ仮澶嶅彞瀛愪腑鐨勯鏂囧瓧銆 + Args: + sentences (list): 鍚湁鍗犱綅绗︾殑鍙ュ瓙鍒楄〃 + placeholder_to_kaomoji (dict): 鍗犱綅绗﹀埌棰滄枃瀛楃殑鏄犲皠琛 + Returns: + list: 鎭㈠棰滄枃瀛楀悗鐨勫彞瀛愬垪琛 + """ + recovered_sentences = [] + for sentence in sentences: + for placeholder, kaomoji in placeholder_to_kaomoji.items(): + sentence = sentence.replace(placeholder, kaomoji) + recovered_sentences.append(sentence) + return recovered_sentences \ No newline at end of file