筆者所在公司項目的報警信息會經過釘釘發送到羣組或我的,這樣若是服務出現了問題咱們都會第一時間收到提醒並進行處理。python
某日從釘釘收到報警信息的我突發奇想,若是本身的項目也能在出現問題的第一時間經過社交工具通知我豈不美 ( sang ) 滋 ( xin )滋( bing ) ( kuang )。git
經過微信公衆平臺進行報警很容易,申請公衆平臺後寫個報警後臺或者使用企業微信進行接口信息發送。但無論是公衆平臺仍是企業微信對於普通用戶的入口太深,並且我的申請還須要提交資料等等一系列事情,顯然不是我想要的結果。github
以前 web 版微信的協議已經有大神解析過並封裝了工具,以後又有優秀的做者不斷完善封裝了更好用的微信我的號接口。web
利用微信我的號接口只要是個微信號就能擔當發送日誌警報的重任,不只能夠發送到我的同時還能發送到羣組。服務器
可是全部微信機器人都是本身主動運行,註冊會話,沒有辦法接收外部程序的日誌或報警,所以我就依託 wxpy 寫了 wechat_sender。微信
wechat_sender 是基於 wxpy 和 tornado 實現的一個能夠將你的網站、爬蟲、腳本等其餘應用中各類消息 (日誌、報警、運行結果等) 發送到微信的工具。微信公衆平臺
使用 wechat_sender 很簡單,只須要有我的微信號,而後用我的微信號啓動 wechat_sender 服務。ide
pip install wechat_sender複製代碼
from wxpy import *
from wechat_sender import *
bot = Bot() # 這裏會掃碼登陸,若是在服務器中請使用 console_qr 參數
listen(bot)
# 以後 wechat_sender 將持續運行等待接收外部消息複製代碼
from wechat_sender import Sender
Sender().send('Hello From Wechat Sender')
# Hello From Wechat Sender 這條消息將經過 1 中登陸微信的文件助手發送給你複製代碼
固然,wechat_sender 支持 添加 logging handler 的方式直接繼承進已有的項目中,例如個人我的的網站、爬蟲腳本等,沒必要修改之前的代碼,只須要在 logger 中增長一個 wechat_sender 的 loghandler 就能夠把相關日誌直接發送到微信中。tornado
舉個栗子:工具
# spider.py
# 假如在一個爬蟲腳本,咱們想讓此腳本的警告信息直接發到微信
# 記得要先用 listen 運行 wechat_sender 服務
import logging
from wechat_sender import LoggingSenderHandler
logger = logging.getLogger(__name__)
# spider code here
def test_spider():
...
logger.exception("EXCEPTION: XXX")
def init_logger():
sender_logger = LoggingSenderHandler('spider', level=logging.EXCEPTION)
logger.addHandler(sender_logger)
if __name__ == '__main__':
init_logger()
test_spider()複製代碼
最後相似效果是這樣滴:
固然,wechat_sender 不只能夠用來發送日誌和警報,你也能夠把他當作日程、會議提醒的利器。
wechat_sender 提供了週期消息和延時消息的功能:
# coding: utf-8
import datetime
from wechat_sender import Sender
sender = Sender()
time = datetime.datetime.now()+datetime.timedelta(hours=1)
sender.delay_send(content="測試內容", time=time, title="測試標題", remind=datetime.timedelta(minutes=59))複製代碼
若是返回正常,1 分鐘後你將收到這條消息時間是 1 小時後的消息提醒:
#標題:測試標題
#時間:2017-06-07 12:56:16
#內容:延遲消息測試複製代碼
做爲一隻猿,頸椎神馬的須要保護好,公司提供了理療服務,但無奈名額有限,每次預定都很困難,因此我決定寫個監控腳本,當有預定名額時經過微信將可預定地址發給我。
寫好監控腳本,而後部署到服務器 celery 週期任務中,每隔 1 分鐘進行一次查詢,同時在服務器上啓動 wechat_sender 服務。
晚上打完球看手機收到了 阿綠( wechat_sender ) 發來的消息,果斷去預定一發。
掃描二維碼,調戲阿綠。驗證信息輸入 'wechat_sender' 或 '加羣' 進入微信交流羣嘗試更多玩法
項目主頁:github.com/bluedazzle/…
詳細文檔:wechat-sender.readthedocs.io/zh_CN/lates…