Python第三方包之DingDingBot釘釘機器人
這個是作者自己封裝的一個釘釘機器人的包,目前只支持發(fā)文本格式、鏈接格式、markdown格式的消息,我們可以在很多場景用到這個,比如告警通知等
安裝
pip install DingDingBot
使用方法
from DingDingBot.DDBOT import DingDing# 初始話DingDingBOt webhook是釘釘機器人所必須的dd = DingDing(webhook=’https://oapi.dingtalk.com/robot/send?access_token=xxxxxxxx’)# 發(fā)送文本消息print(dd.Send_Text_Msg(Content=’test:測試數(shù)據(jù)’))# 發(fā)送鏈接消息print(dd.Send_Link_Msg(Content=’test’,Title=’測試數(shù)據(jù)’,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’))# 發(fā)送Markdown格式的消息print(dd.Send_MardDown_Msg(Content='# 測試數(shù)據(jù)n' + '> testone', Title=’測試數(shù)據(jù)’))
源碼
#!/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: 要發(fā)送的內(nèi)容 :param atMobiles: @指定的人,這里必須是列表,且參數(shù)為手機號 :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: 鏈接的內(nèi)容 :param title: 鏈接的標題 :param MsgUrl: 待跳轉(zhuǎn)頁面的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: @指定的人,這里必須是列表,且參數(shù)為手機號 :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
到此這篇關(guān)于Python第三方包之DingDingBot釘釘機器人的文章就介紹到這了,更多相關(guān)Python DingDingBot內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. PHP循環(huán)與分支知識點梳理2. JSP+Servlet實現(xiàn)文件上傳到服務(wù)器功能3. 利用FastReport傳遞圖片參數(shù)在報表上展示簽名信息的實現(xiàn)方法4. JavaWeb Servlet中url-pattern的使用5. Ajax請求超時與網(wǎng)絡(luò)異常處理圖文詳解6. jsp實現(xiàn)textarea中的文字保存換行空格存到數(shù)據(jù)庫的方法7. jsp EL表達式詳解8. chat.asp聊天程序的編寫方法9. JSP之表單提交get和post的區(qū)別詳解及實例10. jsp cookie+session實現(xiàn)簡易自動登錄
