Skip to content

[aiocqhttp] QQ群日常分析总结插件 - 生成精美的群聊分析报告,支持话题分析、用户形象、群聊圣经等功能

License

Notifications You must be signed in to change notification settings

SXP-Simon/astrbot_plugin_qq_group_daily_analysis

Repository files navigation

QQ群日常分析插件

Plugin Version AstrBot License

✨ 一个基于AstrBot的智能群聊分析插件,能够生成精美的群聊日常分析报告。灵感来源。 ✨

count

功能特色

🎯 智能分析

  • 统计数据: 全面的群聊活跃度和参与度统计
  • 话题分析: 使用LLM智能提取群聊中的热门话题和讨论要点
  • 用户画像: 基于聊天行为分析用户特征,分配个性化称号
  • 圣经识别: 自动筛选出群聊中的精彩发言

📊 可视化报告

  • 多种格式: 支持图片和文本输出格式
    • 精美图片: 生成美观的可视化报告
    • PDF报告: 生成专业的PDF格式分析报告(需配置)
  • 详细数据: 包含消息统计、时间分布、关键词、金句等

🛠️ 灵活配置

  • 群组管理: 支持指定特定群组启用功能
  • 参数调节: 可自定义分析天数、消息数量等参数
  • 定时任务: 支持设置每日自动分析时间
  • 自定义LLM服务 :支持自定义指定的LLM服务

配置选项

Note

以下配置情况仅供参考,请仔细阅读插件配置页面中各个字段的说明,以插件配置中的说明为准。

配置项 说明 备注
启用自动分析 启用定时触发自动分析功能需要按照插件配置里面的说明填写相关的需要的字段;简略说明:打开自动分析功能,在群聊列表中添加群号或者使用 /分析设置 enable 启用当前群聊 默认关闭,需要填写机器人QQ号
PDF格式的报告 初次使用需要使用 /安装PDF 命令安装依赖,首次使用命令安装,最后出现提示告诉你需要重启生效,是对的,需要重启 astrbot,而不是热重载插件。 输出格式需要设置为 PDF
自定义LLM服务 插件配置中允许用户自行选取个人提供的 Astrbot 服务商列表中的大语言模型服务商 留空则回退到用户 Astrbot 现有服务商中第一个可用服务商

Important

PDF 功能配置:使用 /安装PDF 命令后,需要完全重启 AstrBot 才能生效,热重载插件无效!

Tip

自定义 LLM 服务:新版本弃用此前硬编码的 provider 提供方式,采用更符合 Astrbot 生态的更用户友好的配置方式,根据配置键选取 Provider,支持多级回退:

  1. 尝试从配置获取指定的 provider_id(如 topic_provider_id)
  2. 回退到主 LLM provider_id(llm_provider_id)
  3. 回退到当前会话的 Provider(通过 umo)
  4. 回退到第一个可用的 Provider

效果

默认模板效果图

点击展开查看其他模板效果图

format 模板效果图 format效果图

simple 模板效果图(用于展示贡献指南) simple效果图

retro_futurism 模板效果图 retro_futurism效果图

使用方法

基础命令

群分析

/群分析 [天数]
  • 分析群聊近期活动
  • 天数可选,默认为1天
  • 例如:/群分析 3 分析最近3天的群聊

分析设置

/分析设置 [操作]
  • enable: 为当前群启用分析功能
  • disable: 为当前群禁用分析功能
  • status: 查看当前群的启用状态
  • 例如:/分析设置 enable

模板设置

/查看模板
/设置模板 [模板名称或序号]
  • /查看模板: 查看所有可用模板及预览图
  • /设置模板: 查看当前模板和可用模板列表
  • /设置模板 [序号]: 切换到指定序号的模板
  • 例如:/设置模板 1/设置模板 scrapbook

安装要求

Caution

必需条件

  • 已配置 LLM 提供商(用于智能分析)
  • QQ 平台适配器

注意事项

Warning

  1. 性能考虑: 大量消息分析可能消耗较多 LLM tokens
  2. 数据准确性: 分析结果基于可获取的群聊记录,可能不完全准确

常见问题 (FAQ)

获取不到带记录的引用消息

现象: 后台日志出现 [warn] ... 似乎是旧版客户端 ... [error] ... 获取不到带记录的引用消息

原因: 这是由于 NapCat/NTQQ 消息 ID 格式变动、消息过期或临时会话限制导致的。机器人尝试降级使用旧版序号查找失败。

忽略:如果只是偶尔出现(如回复久远消息),不影响机器人核心功能(收发消息),可以直接忽略。

贡献

项目架构图

项目架构图

贡献指南

贡献指南

开发环境设置

为了保持代码质量,本项目使用 pre-commit 钩子进行代码规范检查和自动修复。所有的贡献代码都必须通过 pre-commit 检查。

1. 安装 pre-commit

pip install pre-commit

2. 安装 git hook

在项目根目录下运行,这将确保在每次提交时自动运行检查:

pre-commit install

3. 手动运行检查

如果需要手动触发所有文件的检查(推荐在提交前运行一次):

pre-commit run --all-files

模板贡献指南

🎨 点击展开查看如何贡献你的自定义模板给更多人玩

如果您想为插件贡献新的报告模板,请按照以下步骤操作:

1. 创建模板目录

src/reports/templates/ 目录下创建一个新的文件夹,例如 my_theme

2. 必需文件结构

您的模板目录需要包含以下文件:

src/reports/templates/your_theme_name/
├── image_template.html      # 图片报告主模板
├── pdf_template.html        # PDF报告主模板
├── activity_chart.html      # 活跃度图表组件
├── topic_item.html          # 话题列表项组件
├── user_title_item.html     # 用户称号项组件
└── quote_item.html          # 金句项组件

3. 模板变量说明

主模板 (image_template.html / pdf_template.html) 可用变量:

  • current_date: 当前日期 (YYYY-MM-DD)
  • current_datetime: 当前时间 (YYYY-MM-DD HH:MM:SS)
  • message_count: 消息总数
  • participant_count: 参与人数
  • total_characters: 总字符数
  • emoji_count: 表情数量
  • most_active_period: 最活跃时段
  • hourly_chart_html: 渲染后的活跃度图表 HTML
  • topics_html: 渲染后的热门话题 HTML
  • titles_html: 渲染后的用户称号 HTML
  • quotes_html: 渲染后的金句 HTML
  • total_tokens: Token 消耗统计
  • prompt_tokens: 提示词 Token 消耗
  • completion_tokens: 生成内容 Token 消耗

组件模板可用变量:

  • activity_chart.html: chart_data (包含 hour, count, percentage 的列表)
  • topic_item.html: topic (包含 keyword, count, summary 的对象), loop.index (序号)
  • user_title_item.html: user (包含 nickname, user_id, titles (列表), description 的对象)
  • quote_item.html: quote (包含 content, sender_nickname, reason 的对象)

4. 参考示例

您可以参考 src/reports/templates/simple/ 目录下的文件,这是一个最简化的模板实现,包含了所有必需的基本结构。

5. 模板调试工具

PDF 调试模板命令 Docker 下:

docker exec -it astrbot python data/plugins/astrbot_plugin_qq_group_daily_analysis/scripts/mock_pdf_gen.py

Image 模板调试:

本项目提供了一个专门用于模板开发的调试工具 scripts/debug_render.py,可以在不启动完整 AstrBot 环境的情况下快速预览模板渲染效果。

使用方法:

# 进入项目目录
cd astrbot-qq-group-daily-analysis

# 使用默认模板 (retro_futurism) 渲染
python scripts/debug_render.py

# 指定模板名称渲染
python scripts/debug_render.py -t simple

# 指定输出文件路径
python scripts/debug_render.py -t retro_futurism -o my_output.html

# 查看帮助信息
python scripts/debug_render.py -h

工具特性:

  • 使用 Mock 数据模拟真实的群聊分析结果
  • 无需配置 LLM 服务或启动 AstrBot
  • 输出可使用live server打开 HTML 文件,并进行修改查看
  • 支持所有内置模板的快速切换预览

开发工作流推荐:

  1. 修改模板文件
  2. 运行调试工具生成预览
  3. 在浏览器中打开生成的 HTML 文件查看效果
  4. 重复上述步骤直到满意

许可证

MIT License

欢迎提交Issue和Pull Request来改进这个插件!

About

[aiocqhttp] QQ群日常分析总结插件 - 生成精美的群聊分析报告,支持话题分析、用户形象、群聊圣经等功能

Topics

Resources

License

Stars

Watchers

Forks

Contributors 7