Skip to main content

NoneBot 插件:加载 dot-skill / colleague-skill 蒸馏角色,通过 QQ Bot 进行 AI 角色扮演对话

Project description

NoneBotPluginLogo

NoneBotPluginText

nonebot-plugin-dotcharacter

✨ 加载 dot-skill / colleague-skill 蒸馏角色,通过 QQ Bot 进行 AI 角色扮演对话 ✨

license pypi python

📖 介绍

与 Claude Code 使用 dot-skill 角色对话完全一致:

  1. dot-skill / colleague-skill 从原材料(聊天记录、文档等)蒸馏出角色的 SKILL.md
  2. SKILL.md 包含 PART A(工作能力)和 PART B(人物性格)
  3. 对话时,系统提示词 = PART B 优先定态度 + PART A 供知识
  4. LLM 按照系统提示词生成符合角色风格的回复

本插件做的事情:读取 SKILL.md → 构造系统提示词 → 管理多用户对话历史 → 调用 LLM API → 返回角色回复。

特性

  • 🎭 支持 celebrity / colleague / relationship 三类角色
  • 🤖 支持 9 个 LLM Provider 预设(DeepSeek / OpenAI / Kimi / Qwen / Zhipu / SiliconFlow / Groq / Ollama / Custom)
  • 📂 多目录角色扫描,支持 dot-skill 和 colleague-skill 两种格式
  • 🔥 热加载角色,无需重启
  • 💬 群聊 @机器人 触发对话,命令无需 @
  • 👑 管理员权限控制(命令仅管理员可用)
  • 🧠 私聊会话独立,群聊会话按群共享

💿 安装

使用 nb-cli 安装 在 nonebot2 项目的根目录下打开命令行, 输入以下指令即可安装
nb plugin install nonebot-plugin-dotcharacter
使用包管理器安装 在 nonebot2 项目的插件目录下, 打开命令行, 根据你使用的包管理器, 输入相应的安装命令
pip
pip install nonebot-plugin-dotcharacter
pdm
pdm add nonebot-plugin-dotcharacter
poetry
poetry add nonebot-plugin-dotcharacter

打开 nonebot2 项目根目录下的 pyproject.toml 文件, 在 [tool.nonebot] 部分追加写入

plugins = ["nonebot_plugin_dotcharacter"]

⚙️ 配置

在 nonebot2 项目的 .env 文件中添加下表中的配置

配置项 必填 默认值 说明
DOTCHARACTER_PROVIDER custom LLM Provider 预设:deepseek / openai / kimi / qwen / zhipu / siliconflow / groq / ollama / custom
DOTCHARACTER_API_KEY API Key
DOTCHARACTER_API_BASE https://api.openai.com/v1 API 地址(provider=custom 时有效)
DOTCHARACTER_MODEL gpt-4o-mini 模型名称
DOTCHARACTER_SKILLS_PATH 自动查找 角色目录路径(逗号分隔)
DOTCHARACTER_MAX_HISTORY 20 对话历史条数
DOTCHARACTER_TEMPERATURE 0.8 生成温度 (0.0-2.0)
DOTCHARACTER_MAX_TOKENS 1024 最大 Token 数
DOTCHARACTER_TIMEOUT 60 API 超时秒数
DOTCHARACTER_ADMIN_QQ 管理员 QQ 号(逗号分隔)
DOTCHARACTER_ALLOWED_GROUPS 允许的群号(逗号分隔,留空全部允许)

LLM Provider 预设

Provider 默认模型 Base URL
deepseek deepseek-chat https://api.deepseek.com
openai gpt-4o https://api.openai.com/v1
kimi moonshot-v1-8k https://api.moonshot.cn/v1
qwen qwen-plus https://dashscope.aliyuncs.com/compatible-mode/v1
zhipu glm-4-plus https://open.bigmodel.cn/api/paas/v4
siliconflow Qwen/Qwen2.5-72B-Instruct https://api.siliconflow.cn/v1
groq llama-3.3-70b-versatile https://api.groq.com/openai/v1
ollama llama3 http://localhost:11434/v1
custom gpt-4o-mini 自定义

📂 角色目录结构

DOTCHARACTER_SKILLS_PATH 指向的是 skills 根目录,插件会扫描其下的一级子目录。目录结构必须如下:

skills/                          ← DOTCHARACTER_SKILLS_PATH 指向这里
├── celebrity/                   ← 一级子目录必须是这三类之一
│   └── xiao_xiao_tao_zi_yo/     ← 角色文件夹(文件夹名即 slug)
│       ├── SKILL.md             ← 主技能文件(必须)
│       ├── meta.json            ← 元数据(可选)
│       └── persona.md           ← 人物性格(可选,优先于 SKILL.md 的 PART B)
├── colleague/
│   └── xxx/
└── relationship/
    └── xxx/

注意:角色文件夹必须放在 celebrity/colleague/relationship/ 下,直接放在 skills 根目录不会被识别。

⚠️ 重要提示

NoneBot 命令前缀

本插件的命令以 ! 开头(如 !角色列表),请确保你的 .env 中已配置:

COMMAND_START=["!", "/"]

否则 NoneBot 不会识别命令。

群聊会话机制

  • 群聊:管理员执行 !角色切换 后,全群共享同一个会话。任何群成员 @机器人 发消息都会进入同一个对话历史。
  • 私聊:每个用户与角色的对话历史是独立的。

指令表

指令 权限 需要@ 范围 说明
!角色列表 管理员 群聊/私聊 列出所有可用角色
!角色切换 <名称> 管理员 群聊/私聊 切换到指定角色
!角色退出 管理员 群聊/私聊 退出当前对话
!重置对话 管理员 群聊/私聊 清空对话历史
!角色信息 [名称] 管理员 群聊/私聊 查看角色详情
!角色路径 管理员 群聊/私聊 查看当前扫描的目录
!角色刷新 管理员 群聊/私聊 重新扫描角色目录
!角色导入 add <路径> 管理员 群聊/私聊 添加角色目录
!模型切换 管理员 群聊/私聊 查看当前 LLM 配置
!模型切换 provider <名称> 管理员 群聊/私聊 切换 LLM Provider
!模型切换 model <名称> 管理员 群聊/私聊 切换模型
直接对话 所有人 群聊需要 群聊/私聊 与角色对话

🔗 相关项目

  • colleague-skill — dot-skill 角色蒸馏工具,支持 celebrity / colleague / relationship 三类角色

📄 许可证

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nonebot_plugin_dotcharacter-2.0.3.tar.gz (20.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nonebot_plugin_dotcharacter-2.0.3-py3-none-any.whl (20.0 kB view details)

Uploaded Python 3

File details

Details for the file nonebot_plugin_dotcharacter-2.0.3.tar.gz.

File metadata

File hashes

Hashes for nonebot_plugin_dotcharacter-2.0.3.tar.gz
Algorithm Hash digest
SHA256 4723c8142e4626efefa7d5e7950980b73d7c4b738103659c0456be916da6367a
MD5 9b0c09ef9f48b8a739639dfb1fe98df7
BLAKE2b-256 cdfd201a1fadf11c8f581b7e1e358e83345a1b44e5e9ec55c33427451e9dba21

See more details on using hashes here.

File details

Details for the file nonebot_plugin_dotcharacter-2.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for nonebot_plugin_dotcharacter-2.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 0b3e84cc3547a9c642064674735da0dbdd320e0fcc2ed85c478899182e8b43d4
MD5 9b87b70754298395a475f680322cf613
BLAKE2b-256 521543617976c50ce41e053a6a72ec84fb4eb88445d488c575533b62fedcb830

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page