前言

使用飞书机器人发送消息,本质是使用Python的requests类库发送http请求,请求地址即为创建机器时保存的webhook链接,发送的内容实际为json串,请求header为{'Content-Type': 'application/json; charset=utf-8'}

一、创建飞书机器人  

  自定义飞书机器人操作步骤,具体详见飞书官方文档:《机器人 | 如何在群聊中使用机器人?

二、调用飞书发送消息

  自定义机器人添加完成后,就能向其 webhook 地址发送 POST 请求,从而在群聊中推送消息了。支持推送的消息格式有文本、富文本、图片消息,也可以分享群名片等。

  参数msg_type代表消息类型,可传入:text(文本)/ post(富文本)/ image(图片)/ share_chat(分享群名片)/ interactive(消息卡片),可参照飞书接口文档:https://open.feishu.cn/document/ukTMukTMukTM/uUjNz4SN2MjL1YzM
发送文本消息
  请求的消息体示例:
  1. {
  2. "open_id":"ou_5ad573a6411d72b8305fda3a9c15c70e",
  3. "root_id":"om_40eb06e7b84dc71c03e009ad3c754195",
  4. "chat_id":"oc_5ad11d72b830411d72b836c20",
  5. "user_id": "92e39a99",
  6. "email":"fanlv@gmail.com",
  7. "msg_type":"text",
  8. "content":{
  9. "text":"text content<at user_id=\"ou_88a56e7e8e9f680b682f6905cc09098e\">test</at>"
  10. }
  11. }

Curl 请求 Demo

  1. curl -X POST \
  2. https://open.feishu.cn/open-apis/message/v4/send/ \
  3. -H 'Authorization: Bearer t-fee42159a366c575f2cd2b2acde2ed1e94c89d5f' \
  4. -H 'Content-Type: application/json' \
  5. -d '{
  6. "chat_id": "oc_f5b1a7eb27ae2c7b6adc2a74faf339ff",
  7. "msg_type": "text",
  8. "content": {
  9. "text": "text content<at user_id=\"ou_88a56e7e8e9f680b682f6905cc09098e\">test</at>"
  10. }
  11. }'

使用Python封装飞书请求

接下来我们以发送文本格式消息类型,进行以下封装,上代码:

  1. # -*- coding:utf-8 -*-
  2. '''
  3. @File : feiShuTalk.py
  4. @Time : 2020/11/9 11:45
  5. @Author : DY
  6. @Version : V1.0.0
  7. @Desciption:
  8. '''
  9.  
  10. import requests
  11. import json
  12. import logging
  13. import time
  14. import urllib
  15. import urllib3
  16. urllib3.disable_warnings()
  17.  
  18. try:
  19. JSONDecodeError = json.decoder.JSONDecodeError
  20. except AttributeError:
  21. JSONDecodeError = ValueError
  22.  
  23. def is_not_null_and_blank_str(content):
  24. """
  25. 非空字符串
  26. :param content: 字符串
  27. :return: 非空 - True,空 - False
  28. """
  29. if content and content.strip():
  30. return True
  31. else:
  32. return False
  33.  
  34. class FeiShutalkChatbot(object):
  35.  
  36. def __init__(self, webhook, secret=None, pc_slide=False, fail_notice=False):
  37. '''
  38. 机器人初始化
  39. :param webhook: 飞书群自定义机器人webhook地址
  40. :param secret: 机器人安全设置页面勾选“加签”时需要传入的密钥
  41. :param pc_slide: 消息链接打开方式,默认False为浏览器打开,设置为True时为PC端侧边栏打开
  42. :param fail_notice: 消息发送失败提醒,默认为False不提醒,开发者可以根据返回的消息发送结果自行判断和处理
  43. '''
  44. super(FeiShutalkChatbot, self).__init__()
  45. self.headers = {'Content-Type': 'application/json; charset=utf-8'}
  46. self.webhook = webhook
  47. self.secret = secret
  48. self.pc_slide = pc_slide
  49. self.fail_notice = fail_notice
  50.  
  51. def send_text(self, msg, open_id=[]):
  52. """
  53. 消息类型为text类型
  54. :param msg: 消息内容
  55. :return: 返回消息发送结果
  56. """
  57. data = {"msg_type": "text", "at": {}}
  58. if is_not_null_and_blank_str(msg): # 传入msg非空
  59. data["content"] = {"text": msg}
  60. else:
  61. logging.error("text类型,消息内容不能为空!")
  62. raise ValueError("text类型,消息内容不能为空!")
  63.  
  64. logging.debug('text类型:%s' % data)
  65. return self.post(data)
  66.  
  67. def post(self, data):
  68. """
  69. 发送消息(内容UTF-8编码)
  70. :param data: 消息数据(字典)
  71. :return: 返回消息发送结果
  72. """
  73. try:
  74. post_data = json.dumps(data)
  75. response = requests.post(self.webhook, headers=self.headers, data=post_data, verify=False)
  76. except requests.exceptions.HTTPError as exc:
  77. logging.error("消息发送失败, HTTP error: %d, reason: %s" % (exc.response.status_code, exc.response.reason))
  78. raise
  79. except requests.exceptions.ConnectionError:
  80. logging.error("消息发送失败,HTTP connection error!")
  81. raise
  82. except requests.exceptions.Timeout:
  83. logging.error("消息发送失败,Timeout error!")
  84. raise
  85. except requests.exceptions.RequestException:
  86. logging.error("消息发送失败, Request Exception!")
  87. raise
  88. else:
  89. try:
  90. result = response.json()
  91. except JSONDecodeError:
  92. logging.error("服务器响应异常,状态码:%s,响应内容:%s" % (response.status_code, response.text))
  93. return {'errcode': 500, 'errmsg': '服务器响应异常'}
  94. else:
  95. logging.debug('发送结果:%s' % result)
  96. # 消息发送失败提醒(errcode 不为 0,表示消息发送异常),默认不提醒,开发者可以根据返回的消息发送结果自行判断和处理
  97. if self.fail_notice and result.get('errcode', True):
  98. time_now = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(time.time()))
  99. error_data = {
  100. "msgtype": "text",
  101. "text": {
  102. "content": "[注意-自动通知]飞书机器人消息发送失败,时间:%s,原因:%s,请及时跟进,谢谢!" % (
  103. time_now, result['errmsg'] if result.get('errmsg', False) else '未知异常')
  104. },
  105. "at": {
  106. "isAtAll": False
  107. }
  108. }
  109. logging.error("消息发送失败,自动通知:%s" % error_data)
  110. requests.post(self.webhook, headers=self.headers, data=json.dumps(error_data))
  111. return result

  封装后我们就可以直接调用封装的类,进行消息代码发送;webhook即是创建机器人时生成的webhook链接,执行以下代码后,就可以使用飞书发送消息咯~

  1. webhook = "https://open.feishu.cn/XXXXXXX"
  2. feishu = FeiShutalkChatbot(webhook)
  3. feishu.send_text("重庆百货-新世纪鱼胡路店内商品'1000800370-牛心白 约1kg'在商详[8]和榜单[7]中排名不一致")

Python调用飞书发送消息的更多相关文章

  1. 关于 使用python向qq好友发送消息(对爬虫的作用----当程序执行完毕或者报错无限给自己qq发送消息,直到关闭)

    以前看到网上一些小程序,在处理完事物后会自动发送qq消息,但是一直搞不懂是说明原理.也在网上找过一些python登陆qq发送消息的文字,但是都太复杂了.今天偶然看到一篇文章,是用python调用win ...

  2. 个人微信公众号搭建Python实现 -接收和发送消息-基本说明与实现(14.2.1)

    @ 目录 1.原理 2.接收普通消息 3.接收代码普通消息代码实现 1.原理 2.接收普通消息 其他消息类似参考官方文档 3.接收代码普通消息代码实现 from flask import Flask, ...

  3. Python 微信公众号发送消息

    1. 公众号测试地址 https://mp.weixin.qq.com/debug/cgi-bin/sandboxinfo?action=showinfo&t=sandbox/index 2. ...

  4. python 钉钉机器人发送消息

    import json import requests def sendmessage(message): url = 'https://oapi.dingtalk.com/robot/send?ac ...

  5. 使用python对mysql主从进行监控,并调用钉钉发送报警信息

    1.编写python的监控脚本 A.通过获取mysql库中的状态值来判断这个mysql主从状态是否正常 B.进行两个状态值的判断 C.进行调取钉钉机器人,发送消息 2.设置定时任务进行脚本运行 cro ...

  6. Java企业微信开发_05_消息推送之发送消息(主动)

    一.本节要点 1.发送消息与被动回复消息 (1)流程不同:发送消息是第三方服务器主动通知微信服务器向用户发消息.而被动回复消息是 用户发送消息之后,微信服务器将消息传递给 第三方服务器,第三方服务器接 ...

  7. Kafka生产者发送消息的三种方式

    Kafka是一种分布式的基于发布/订阅的消息系统,它的高吞吐量.灵活的offset是其它消息系统所没有的. Kafka发送消息主要有三种方式: 1.发送并忘记 2.同步发送 3.异步发送+回调函数 下 ...

  8. 如何在MFC DLL中向C#类发送消息

    如何在MFC DLL中向C#类发送消息 一. 引言 由于Windows Message才是Windows平台的通用数据流通格式,故在跨语言传输数据时,Message是一个不错的选择,本文档将描述如何在 ...

  9. activeMq发送消息流程

    1,发送消息入口 Message message = messageBean.getMessageCreator().createMessage(session); producer.send(mes ...

随机推荐

  1. 054 01 Android 零基础入门 01 Java基础语法 06 Java一维数组 01 数组概述

    054 01 Android 零基础入门 01 Java基础语法 06 Java一维数组 01 数组概述 本文知识点:数组概述 为什么要学习数组? 实际问题: 比如我们要对学生的成绩进行排序,一个班级 ...

  2. Oracle Database XE 11gR2 SQL 命令行的显示调整

    操作系统:Windows 10 x64 Oracle Database XE 11gR2 参考:在cmd命令行使用sqlplus时的页面显示问题 通过 cmd 命令行或运行 SQL 命令行查看一张表的 ...

  3. 上帝视角一文理解JavaScript原型和原型链

    本文呆鹅原创,原文地址:https://juejin.im/user/307518987058686/posts 前言 本文将从上帝角度讲解JS的世界,在这个过程中,大家就能完全理解JS的原型和原型链 ...

  4. 返回头添加cookie信息

    返回类型 HttpResponseMessage //构建返回对象 var res= Request.CreateResponse(HttpStstusCode.Ok,返回体) //创建cookie对 ...

  5. OAth 2.0 的白话讲解

    一.OAuth2.0是什么,主要做什么用的? 官方注解 简单说,OAuth 就是一种授权机制.数据的所有者告诉系统,同意授权第三方应用进入系统,获取这些数据.系统从而产生一个短期的进入令牌(token ...

  6. mysql CHAR and VARCHAR 比较

    写在前面 面试的时候突然有一位面试官问,说说CHAR和VARCHAR的区别,懵逼了,想自己平常使用的时候直接把VARCHAR拿来就用,真没注意到其中的不同. 反思,为什么没有注意到他们的不同 对于my ...

  7. 利用Turtle绘制各种图形

    首先引入函数库: 第一种: import turtle  import turtle as t 第二种: from turtle import * 1:使用 turtle 库的 turtle.fd() ...

  8. MacBook连接蓝牙鼠标、蓝牙键盘失败的解决方案

    问题: keychron k4连接不上MacBook,但是win10和iPhone都可以成功连接. 解决方法: 1.关闭wifi: 2.连接蓝牙键盘: 3.稍等一会,再连接wifi就可以了. 另外,苹 ...

  9. swoft配置连接池

    bean.php 'db' => [ 'class' => Database::class, 'dsn' => 'mysql:dbname=test;host=127.0.0.1', ...

  10. 第八章 nginx基础介绍

    一.nginx概述 nginx是一个开源且高性能.可靠的http web服务.代理服务. 开源:直接获取源代码 高性能:支持海量并发 可靠:服务稳定 二.nginx特点 1.高性能高并发 性能高,支持 ...