Python第三方包之DingDingBot釘釘機器人
這個是作者自己封裝的一個釘釘機器人的包,目前只支持發文本格式、鏈接格式、markdown格式的消息,我們可以在很多場景用到這個,比如告警通知等
安裝
pip install DingDingBot
使用方法
from DingDingBot.DDBOT import DingDing# 初始話DingDingBOt webhook是釘釘機器人所必須的dd = DingDing(webhook=’https://oapi.dingtalk.com/robot/send?access_token=xxxxxxxx’)# 發送文本消息print(dd.Send_Text_Msg(Content=’test:測試數據’))# 發送鏈接消息print(dd.Send_Link_Msg(Content=’test’,Title=’測試數據’,MsgUrl=’https://www.baidu.com’,PicUrl=’https://cn.bing.com/images/search?q=outgoing%e6%9c%ba%e5%99%a8%e4%ba%ba&id=FEE700371845D9386738AAAA51DCC43DC54911AA&FORM=IQFRBA’))# 發送Markdown格式的消息print(dd.Send_MardDown_Msg(Content='# 測試數據n' + '> testone', Title=’測試數據’))
源碼
#!/usr/bin/python# -*- coding: UTF-8 -*-’’’ @@@@@@@@ @@@@@@@@@ @@@@@@@@@ @@@@@@@@@ @@@@@@@@@@@@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@ @@@@@@@@@ @@’’’import requests, jsonclass DingDing(): ''' # 釘釘官方文檔 Refer to official documentation: https://ding-doc.dingtalk.com/doc#/serverapi2/qf2nxq ''' # 初始化 def __init__(self, webhook): self.webhook = webhook self.session = requests.session() self.session.headers = {'Content-Type': 'application/json;charset=utf-8'} def Send_Text_Msg(self, Content: str, atMobiles: list = [], isAtAll: bool = False) -> dict: ''' :param content: 要發送的內容 :param atMobiles: @指定的人,這里必須是列表,且參數為手機號 :param isAtAll: @全體成員 :return: ''' try: data = {'msgtype': 'text','text': { 'content': Content},'at': { 'atMobiles': atMobiles, 'isAtAll': isAtAll} } response = self.session.post(self.webhook, data=json.dumps(data)) if response.status_code == ’200’:result = {'status': True, 'message': 'Message has been sent'}return result else:return response.text except Exception as error: result = {'status': False, 'message': f'Failed to send message,Error stack:{error}'} return result def Send_Link_Msg(self, Content: str, Title: str, MsgUrl: str, PicUrl: str = ’’): ''' :param Content: 鏈接的內容 :param title: 鏈接的標題 :param MsgUrl: 待跳轉頁面的url :param PicUrl: 消息所展示的圖片 :return: ''' try: data = {'msgtype': 'link','link': { 'text': Content, 'title': Title, 'picUrl': PicUrl, 'messageUrl': MsgUrl} } response = self.session.post(self.webhook, data=json.dumps(data)) if response.status_code == ’200’:result = {'status': True, 'message': 'Message has been sent'}return result else:return response.text except Exception as error: result = {'status': False, 'message': f'Failed to send message,Error stack:{error}'} return result def Send_MardDown_Msg(self, Content: str, Title: str, atMobiles: list = [], isAtAll: bool = False): ''' :param Content: Markdown格式的文本,僅支持下面的格式 ’’’ 標題 # 一級標題 ## 二級標題 ### 三級標題 #### 四級標題 ##### 五級標題 ###### 六級標題 引用 > A man who stands for nothing will fall for anything. 文字加粗、斜體 **bold** *italic* 鏈接 [this is a link](http://name.com) 圖片  無序列表 - item1 - item2 有序列表 1. item1 2. item2 ’’’ :param Title: 這個Markdown的標題 :param atMobiles: @指定的人,這里必須是列表,且參數為手機號 :param isAtAll: @全體成員 :return: ''' try: data = {'msgtype': 'markdown','markdown': { 'title': Title, 'text': Content},'at': { 'atMobiles': atMobiles, 'isAtAll': isAtAll} } response = self.session.post(self.webhook, data=json.dumps(data)) if response.status_code == ’200’:result = {'status': True, 'message': 'Message has been sent'}return result else:return response.text except Exception as error: result = {'status': False, 'message': f'Failed to send message,Error stack:{error}'} return result
到此這篇關于Python第三方包之DingDingBot釘釘機器人的文章就介紹到這了,更多相關Python DingDingBot內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章: