Skip to main content

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

Project description

QQ 邮件登记机器人插件

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

版本:0.7.2

本版本将原 mail_v7.py 单文件插件重构为 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 单次允许上传并识别的最大图片数量。

说明

  • 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.2.tar.gz (44.8 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.2-py3-none-any.whl (51.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: nonebot_plugin_mail-0.7.2.tar.gz
  • Upload date:
  • Size: 44.8 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.2.tar.gz
Algorithm Hash digest
SHA256 5adb6091a1a35c1dbb2f92003ac7e40bac37a87e65cbb4f08f2a77fcbd137f5b
MD5 f3845e626c5dabbc8de91360e3c31bcd
BLAKE2b-256 dd12420704b0174be87f3f84ee3abdc01639b006638774633686e785d4b1bd83

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for nonebot_plugin_mail-0.7.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b8d3697cf448e2af59a2c60e4057086a10762069e01fff9d632da94679b7b5ed
MD5 24c9e968317c05173a2a01ec9f04ca90
BLAKE2b-256 2204fa003f946f5f8a23877c6e13ba0646b4cdda06c9c5e2dbc4162fa4776a44

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