Skip to main content

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

Project description

QQ 邮件登记机器人插件

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

版本:0.7.4

本版本相比0.7.3增加群黑名单功能。

安装

  • 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
group_blacklist = []

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 单次允许上传并识别的最大图片数量。

其他

配置项 必填 默认值 说明
group_blacklist [631145926] /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.4.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.4-py3-none-any.whl (52.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: nonebot_plugin_mail-0.7.4.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.4.tar.gz
Algorithm Hash digest
SHA256 1b698036a9194c19625b7373c6b43e29325dc4d2fa9436a2f43de3ff79e704c7
MD5 56fe19d66cfbda573ab5cd061dafe9e1
BLAKE2b-256 d7b9ff879cc1b69507ede40cc3d7b2a3ce7af560617a16f86ed332dffa63b922

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for nonebot_plugin_mail-0.7.4-py3-none-any.whl
Algorithm Hash digest
SHA256 eb2a4af72640fa30cc74e03b0b108c604e4ff6dcd02bad40678587a383736243
MD5 874988e06f4ba4c26d1a3511c9020147
BLAKE2b-256 2b3818029fac7bd7075f443d6bd75b50fff2c4a522f97f0f77dc1a5538489655

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