当前位置: 首页 > article >正文

python脚本实现接入企微机器人

企业微信中的群聊机器人在日常办公中无处不在,对提升工作效率、保证消息及时送达提供了重要的技术保障。例如:DevOps助手、JIRA、构建通知等;还常常使用在运维服务器中配合Prometheus监控体系及时发送告警信息等

文章目录

  • 源码示例
  • Demo源码处理逻辑
    • 步骤一:获取json格式的参数
    • 步骤二:将json中的信息进行解析

源码示例

例子:广播每日天气

from doctest import debug_script
from pydoc import describe
from flask import jsonify
import requests
import simplejson

url = "http://t.weather.itboy.net/api/weather/city/101010100"  # 替换为你要请求的URL
robot_url = "https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=XXXX"

def alert(shidu, pm25, quality, wendu, ganmao, forecast):
    content = "## **<font color=\"green\">天气预报</font>** \n>**湿度:** <font color=\"warning\">{0}</font>\n>**PM2.5:** <font color=\"warning\">{1}</font>\n>**空气质量:** {2}\n>**温度:** {3}\n>**感冒指数:** {4}\n>**日期:** {5}日\n>**最高温度:** {6}\n>**最低温度:** {7}\n>**风向:** {8}\n>**天气状况:** {9}\n {10}"

    params = simplejson.dumps({
        "msgtype": "text",
        "text": {
                "content":content.format(shidu, pm25, quality, wendu, ganmao, forecast[0]['date'], forecast[0]['high'], forecast[0]['low'], forecast[0]['fx'], forecast[0]['type'], forecast[0]['notice']),
                "mentioned_list": ["@all"]
            }
        })


    return params


def webhook_url(params,url_key):
    headers = {"Content-type": "application/json"}
    """
    *****重要*****
    """
    url = "{}".format(url_key)
    r = requests.post(url,params,headers)






# 发送GET请求
response = requests.get(url)
# 获取响应结果
data = simplejson.loads(response.text)
webhook_url(alert(data['data']['shidu'],data['data']['pm25'],data['data']['quality'],data['data']['wendu'],data['data']['ganmao'], data['data']['forecast']),  robot_url)


Demo源码处理逻辑

步骤一:获取json格式的参数

这个参数来自于你要处理的上游业务系统,例如你要实现一个服务器告警机器人,则你需要接收到告警的相关信息;例如你要实现一个广播天气情况的机器人,则你需要接收到天气相关json回参。

步骤二:将json中的信息进行解析

封装到符合企业微信机器人可以接收的消息格式中
企业微信机器人可以接受的消息格式:详见机器人配置说明
常用的两种:文本类型、markdown类型
文本类型:

{
    "msgtype": "text",
    "text": {
        "content": "广州今日天气:29度,大部分多云,降雨概率:60%",
        "mentioned_list":["wangqing","@all"],
        "mentioned_mobile_list":["13800001111","@all"]
    }
}

在这里插入图片描述
在这里插入图片描述

markdown类型:

{
    "msgtype": "markdown",
    "markdown": {
        "content": "实时新增用户反馈<font color=\"warning\">132</font>,请相关同事注意。\n
         >类型:<font color=\"comment\">用户反馈</font>
         >普通用户反馈:<font color=\"comment\">117</font>
         >VIP用户反馈:<font color=\"comment\">15例</font>"
    }
}

在这里插入图片描述

在这里插入图片描述

使用区别:
markdown编辑内容模板更加丰富,可以突出重点;无法@人员
文本消息只能发送文本内容;支持@所有人/固定人员

(3)发送请求即可,发送成功后,企业微信机器人就会在群聊中发送自定义格式的消息内容。


http://www.kler.cn/a/555711.html

相关文章:

  • CTA策略【量化理论】
  • vscode复制到下一行
  • 企业建站源码系统 php企业网站源码模板
  • 【后端基础】布隆过滤器原理
  • flutter将utf-8编码的字节序列转换为中英文字符串
  • vxe-table 如何实现跟 Excel 一样的数值或金额的负数自动显示红色字体
  • 大数据技术之HBase操作归纳
  • PyTorch 源码学习:Dispatch Autograd Operators
  • 高级SQL技术在Python项目中的应用:更进一步的数据分析与集成
  • [C#]C# winform部署yolov12目标检测的onnx模型
  • 【MCU输入捕获模式】
  • 深度优化方法汇总
  • webSocket发送实时通知实例
  • 数据结构:串( Bunch)及其实现
  • Hadoop-HA集群部署
  • go 模块管理
  • 蓝桥杯 Java B 组之岛屿数量、二叉树路径和(区分DFS与回溯)
  • 【Linux网络编程】IP协议格式,解包步骤
  • List的基本功能(1)
  • 以ChatGPT为例解析大模型背后的技术