Python 实现企业微信外部群机器人:轻量化消息推送方案

核心功能:群机器人 Webhook 开发(Python 版)


能力介绍

群机器人 Webhook 是企业微信为外部群提供的一种简单、高效的数据推送信道。Python 开发者只需利用基础的 HTTP 请求库,即可实现从本地或服务器向企微群实时发送通知。其核心价值在于极简集成:无需处理复杂的 OAuth2.0 认证,非常适合脚本告警、自动化报表推送等"单向通知"场景。

10 分钟接入 Demo

  1. 获取 Webhook :在企业微信群设置中,依次点击"群机器人" -> "添加机器人",保存生成的 Webhook URL

  2. 安装依赖 :确保环境已安装 requests 库(pip install requests)。

  3. 封装数据 :按照官方 JSON 格式构造 Python 字典,包含 msgtype(文本、Markdown、图片等)。

  4. 执行推送 :使用 requests.post() 将数据发送至 Webhook 地址。

  5. 处理响应 :解析返回的 JSON,确认 errcode 是否为 0。

API 示例代码

以下是使用 Python 发送 Markdown@特定成员 的标准代码片段:

python 复制代码
import requests
import json

def send_qiwe_robot_msg(webhook_url, content, mentioned_list=None):
    """
    通过 Webhook 发送机器人消息
    """
    headers = {"Content-Type": "application/json"}
    
    # 构造 Markdown 消息体
    payload = {
        "msgtype": "markdown",
        "markdown": {
            "content": content
        }
    }
    
    # 如果需要 @ 成员(注意:Markdown 模式下需在 content 中拼入 <@userid>)
    if mentioned_list:
        mention_str = "".join([f"<@={uid}>" for uid in mentioned_list])
        payload["markdown"]["content"] += f"\n\n提醒:{mention_str}"

    response = requests.post(webhook_url, data=json.dumps(payload), headers=headers)
    return response.json()

# 使用示例
WEBHOOK = "https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=YOUR_KEY"
MSG = """# 自动化任务监控报告
> **任务名称**:数据备份
> **状态**:<font color="info">执行成功</font>
> **耗时**:45s
"""

# res = send_qiwe_robot_msg(WEBHOOK, MSG, mentioned_list=["ZhongGong"])
# print(res)

使用场景说明

  • 运维监控告警:当 Python 监控脚本发现服务器磁盘空间不足或接口超时,第一时间触发群通知。

  • 数据分析日报 :利用 pandas 处理完业务数据后,将核心指标格式化为 Markdown 表格推送到管理群。

  • 开发流自动化:在 CI/CD 流程中,当脚本部署完成或测试失败时,自动在开发群同步结果。

FAQ

  • Q:为什么发送的消息中 @ 成员没有变色提醒?

    • A:在 Markdown 消息中,必须使用 <@userid> 格式(如果需要 @ 所有人,则使用 <@all>)。
  • Q:机器人可以发送本地文件吗?

    • A:可以。但需要先调用"上传临时素材"接口获取 media_id,再通过机器人发送 file 类型消息。
  • Q:接口调用报错 40037 (invalid key)?

    • A:请检查 Webhook URL 后的 key 参数是否完整,或者该机器人是否已被管理员移除。

引导入口

相关推荐
ID_180079054736 小时前
除了 Python,还有哪些语言可以解析 JSON 数据?
开发语言·python·json
FreakStudio6 小时前
小作坊 GitHub 协作闭环:fork-sync-dev-pr-merge 实战指南
python·单片机·嵌入式·面向对象·电子diy
普通网友7 小时前
阿里云国际版服务器,真的是学生党的性价比之选吗?
后端·python·阿里云·flask·云计算
小陈工8 小时前
2026年4月2日技术资讯洞察:数据库融合革命、端侧AI突破与脑机接口产业化
开发语言·前端·数据库·人工智能·python·安全
陈晓明start8 小时前
【python】豆包模型,自动生成测试用例初探索
python
阿kun要赚马内8 小时前
Python中元组和列表差异:底层结构分析
开发语言·python
万添裁9 小时前
pytorch的张量数据结构以及各种操作函数的底层原理
人工智能·pytorch·python
浔川python社9 小时前
张雪机车:以热爱为轮,让中国摩托驰骋世界之巅
python
zl_dfq9 小时前
Python学习5 之【字符串】
python·学习