Skip to main content

QQ 邮件登记机器人插件,支持 Notion 邮件登记、查询、签收和群聊信封图片智能识别。

Project description

QQ 邮件登记机器人插件

一个基于 NoneBot2 + OneBot v11 的 QQ 机器人文件夹插件,用于管理“寄信 / 查件 / 签收 / 联系人表 / 邮件记录表”,并将数据同步到 Notion。

版本:见pyproject.toml.project.version

本版本相比0.7.6增加群白名单功能。

安装

  • nb plugin install nonebot-plugin-mail

  • pip install nonebot-plugin-mail

然后在项目里加载此插件

功能

  • /mail contacts:查看联系人表图片
  • /mail records:查看最新邮件记录图片
  • /mail @某人:查看联系人信息
  • /寄信 / 寄件 / 寄出:进入人工寄件登记流程
  • /查询 / 查件:查询最近 7 天内是否有人给自己寄信
  • /签收 / 收件:查询并签收未签收邮件
  • /识别信件 / 智能寄信 / 信件识别 / 识别邮件:群聊发送信封图片,使用视觉 AI 识别后人工确认写入 Notion

智能识别流程

  1. 群内发送 /识别信件
  2. 按提示发送一张或多张信封图片。
  3. 插件下载图片并尝试压缩到最长边 2200px、JPEG 质量 0.92。
  4. 视觉 AI 识别寄件人、收件人、寄出日期、邮件类型和参考备注。
  5. 后端规则校验联系人 ID、日期、邮件类型、澳门收件人规则,并做电话、QQ、姓名、别名、地址兜底匹配。
  6. 群内返回识别结果预览。
  7. 回复 确认 后写入 Notion。

如需修改识别结果,可在确认前回复类似:

收件人 @某人
寄件人 @某人
日期2026-06-09
类型挂号信
编号XA123456789

配置

在 NoneBot 2 环境配置 .env.env.dev 中设置:

示例

NOTION_TOKEN=
RAS_DATA_SOURCE_ID=31e70d82-c716-80ba-b4d2-000b1892f62c
CONTACT_DATA_SOURCE_ID=31e70d82-c716-8034-b23d-000ba20878af
AI_BASE_URL=https://api.exesim.com/v1
AI_API_KEY=
AI_MODEL=Qwen3.6-Plus
MAIL_IMAGE_MAX_COUNT=12

Notion 相关

配置项 必填 默认值 说明
NOTION_TOKEN 否,但不建议 Notion API 访问令牌,用于读取联系人表、写入邮件记录、签收邮件记录。
RAS_DATA_SOURCE_ID 否,但不建议 31e70d82-c716-80ba-b4d2-000b1892f62c 邮件记录表的数据源 ID,用于查询邮件记录。
CONTACT_DATA_SOURCE_ID 否,但不建议 31e70d82-c716-8034-b23d-000ba20878af 联系人表的数据源 ID,用于读取联系人信息。

AI 相关

配置项 必填 默认值 说明
AI_BASE_URL https://api.openai.com/v1 兼容 OpenAI 接口的视觉模型地址。
AI_API_KEY 视觉识别接口的访问密钥。
AI_MODEL Qwen3.6-Plus 识别信封图片时使用的模型名称。
MAIL_IMAGE_MAX_COUNT 12 单次允许上传并识别的最大图片数量。

其他

配置项 必填 默认值 说明
mail_group_whitelist(list[int]) [] /mail命令的群白名单列表,空或不配置表示白名单不生效,有值表示只在这些群生效

说明

  • AI_BASE_URL 可不填,不填时默认使用 https://api.openai.com/v1
  • MAIL_IMAGE_MAX_COUNT 可不填,不填时默认 12
  • NOTION_TOKEN 不填时,联系人表会尝试使用本地 fallback,但邮件查询、签收和提交 Notion 仍会受限,基本必须

notion侧配置

  • 创建的表应当至少包括 联系人表、邮件记录表
  • 联系人表应当至少包含如下列:姓名 / 昵称,电话,邮编 1, 地址 1, 邮编 2, 地址 2, QQ
  • 其中QQ可以用英文逗号分隔多个
  • 邮件记录表需要包括:消息来源,签收,收件人,寄出日期,邮件编号,寄件人,备注

参考:

image f3fb19bb-b182-491d-b7ca-10607eea9afd

目录

  nonebot_plugin_mail/
    __init__.py              # 插件入口:PluginMetadata、注册所有 handlers
    config.py                # 配置:Notion、AI_BASE_URL、AI_API_KEY、AI_MODEL、数据库 ID
    models.py                # Contact、RecognizeResult、MailRecordDraft 等数据结构
    constants.py             # 邮件类型、字段名、默认值、正则、澳门规则常量

    services/
      notion.py              # Notion 联系人读取、邮件记录写入/查询/签收
      contacts.py            # 联系人缓存、fallback 合并、QQ 映射、联系人公开字段
      recognizer.py          # 视觉 AI 调用、prompt 构造、AI JSON 解析
      matcher.py             # 联系人匹配:电话、QQ、姓名/别名、地址片段评分
      rules.py               # AI 结果归一化:日期、邮件类型、条码、澳门收件人、错误项
      images.py              # 群聊图片下载、压缩/转 base64、图片临时保存
      render.py              # 联系人表、邮件记录、识别结果预览转图片/文本

    handlers/
      mail.py                # /mail contacts、/mail records、/mail @某人
      send.py                # “寄信/寄件/寄出”人工登记流程
      query.py               # “查询/查件”
      receive.py             # “签收/收件”
      recognize.py           # 识别信件/智能寄信/信件识别/识别邮件 发送信件图片触发智能识别、人工确认、提交 Notion

    data/
      fallback_contacts.py   # notion不可用时的临时contacts

示例

/mail @某人

image

/寄件

image image

/查件

image

/签收

image

/信件识别

IMG_20260609_224224

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_mail-0.7.7.tar.gz (45.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_mail-0.7.7-py3-none-any.whl (52.1 kB view details)

Uploaded Python 3

File details

Details for the file nonebot_plugin_mail-0.7.7.tar.gz.

File metadata

  • Download URL: nonebot_plugin_mail-0.7.7.tar.gz
  • Upload date:
  • Size: 45.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.11

File hashes

Hashes for nonebot_plugin_mail-0.7.7.tar.gz
Algorithm Hash digest
SHA256 c757f477a53b54aaa327757b07351e0dea63e298dd52daa2f98414b6f0cf2ccc
MD5 81f08e8b36f10de58f963e693b6202f9
BLAKE2b-256 5e50cc5de9515a5c7583fbdf633277658a7aca8be17553514e8eb84df30b4423

See more details on using hashes here.

File details

Details for the file nonebot_plugin_mail-0.7.7-py3-none-any.whl.

File metadata

File hashes

Hashes for nonebot_plugin_mail-0.7.7-py3-none-any.whl
Algorithm Hash digest
SHA256 e6a92cfa71e75b5378121e6301064d0c081741fa122421f4265211915d6c9274
MD5 6fa92a9327546d9d42a049e501a4804c
BLAKE2b-256 9ff399ee29276358cf24ca1716d03555720281b496d01c1f9f5addfcb8fa5aae

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