前言 有沒有小伙伴跟我一樣,最近工作比較繁雜,經常忘事,有時候記了備忘錄結果卻忘記看備忘錄,但是微信是每天都會看的,於 是就想到寫 一個基於微信的提醒系統。總體思路是將待辦事項記錄到線上記事本,通過建立定時任務,每天早上爬取文檔中記 錄 的待辦事項,篩選出當日需要處理的事項,併發送到自己微信。 1任 ...
前言
有沒有小伙伴跟我一樣,最近工作比較繁雜,經常忘事,有時候記了備忘錄結果卻忘記看備忘錄,但是微信是每天都會看的,於
是就想到寫 一個基於微信的提醒系統。總體思路是將待辦事項記錄到線上記事本,通過建立定時任務,每天早上爬取文檔中記 錄
的待辦事項,篩選出當日需要處理的事項,併發送到自己微信。
1任何的記錄與提取
1).任務記錄
為了便於爬取,推薦使用網頁版的線上記事本,現在這種工具很多,我選擇“石墨文檔”進行操作演示。記錄內容的 格式可以根據
自己的需求和爬蟲自行確定,例如我在11月20日之前記錄了一份以下樣式的任務清單:
Python學習交流Q群:906715085### 11月21日 9:30 吃飯 11月21日 12:30 睡覺 11月21日 14:00 打豆豆 11月22日 9:00 去南極旅游 11月23日 18:00 請豆豆吃火鍋
2).模擬登錄
使用爬蟲來實現待辦事項的提取,發現線上記事本是需要登錄的:
模擬登錄的方法很多,這裡我選擇selenium模擬的方式進行登錄操作,分別在“手機號或郵箱”和“密碼”兩欄輸入自 己的登錄名和密
碼,然後點擊“立即登錄”按鈕完成登陸,部分核心代碼如下:
3).任務提取
登錄後要指定跳轉到記錄自己待辦事項的頁面,然後使用selenium.webdriver對象的page_source屬性可以很容易獲取到頁面的
html,經過解析獲取待辦事項的數據信息。代碼如下:
當然,有時候我們會在記事本里記錄很多需要辦理的事項,執行日期也會比較分散,但是沒必要每天對所有的待辦事項進行提
醒。對此,我們可以篩選出當天需要辦理的事項進行提醒,這樣效果無疑會更好一些。任務篩選的基本思路是獲取系統當天日
期,將它與各事項的待辦日期逐一進行匹配,代碼如下:
2信息推送到微信
1).server醬
說到推送信息到微信,不得不介紹一個很方便的工具——server醬。說的簡單一點,server醬就是一款能向目標微信賬號發送信息
的工具,她最大的有點就是功能簡單、使用方便、輕量,使用server醬只需下麵幾個步驟:
•登入:用GitHub賬號登入網站,獲得自己的SCKEY。
•綁定:通過微信掃碼關註完成綁定。
•發消息:往 http://sc.ftqq.com/SCKEY.send 發GET請求,就可以在微信里收到消息。
另外,server醬還提供了網頁版的線上發送工具,可以進行體驗和測試。值得一提的是,server醬的初始目的是通過手機監測服務
器報警和日誌,因此為避免程式出錯,限制了每人每天發 送上限500條,相同內容5分鐘內不能重覆發送,不同內容一分鐘只能發
送30條。對於本系統來說,這個數據上限 絕對綽綽有餘了。
2)信息推送
介紹完了server醬,就來試試她的效果吧。
首先我們要明確發送get請求的地址,即上面第三步中的URL,這個URL的關鍵取決於自己的SCKEY,之後要設置發 送信息的標
題和內容,然後向目標URL發送請求即可完成信息的推送,順利 的話馬上就能在微信中收到信息提醒了。
3定時任務與檢測
1)定時任務
現在我們需要設置一個定時任務,這裡使用APScheduler來實現。APScheduler是基於Quartz的一個python定時任務框架,提供了
若幹種類的調度器,由於我們的定時任務進在當前進程中執行,所以選擇BlockingScheduler調度器,然後通過add_job來動態增
加待執行的任務。
關於APScheduler,其實並不需要瞭解太多,因為它的基本用法非常簡單:
•entrance為主功能函數,用於爬取線上記事本中的信息、篩選出當天需要辦理的事項並通過server醬發送到 微信;
•day_of_week表示定時任務在一周中的哪幾天執行,0-6分別代表周一至周日,也可以指定某個值,比如‘0’表 示僅在周一執行;
•hour、minute和second分別代表定時任務執行的時、分、秒,這幾個參數既可以指定某個值也可以向day_of_week一樣設置範
圍,甚至設置執行的間隔頻率。
將程式放到服務中,通過start()方法啟動定時任務調度器,這樣在每天早上的7:30微信中就會收到當天待辦事項 的有關提示。
2).運行監測
現在還有一個問題,就是要保證我們的程式始終處於正常運行的狀態,上面說過,server醬通過向目標URL發送get請求的方式推
送信息,而這個get請求是有返回值的,其格式為“{‘errno’: 0, ‘errmsg’: ‘success’, ‘dataset’: ‘done’}”,其中若errno為0則表示發送成
功,否則會在errmsg中給出錯誤信息。基於此,我們可以依托logging模塊記錄程式每天的運行狀態,以便及時發現問題。相關代
碼如下:
logging.basicConfig(filename='log.log', format='%(asctime)s:%(message)s', level=logging.INFO) if response.json()['errno'] == 0: logging.info('發送成功') else: logging.warning('發送失敗 %s' %response.json()['errmsg'])
(代碼左右滑動)
最後,我們來演示一下系統的運行效果,以文章開頭部分的記事本內容為例,在11月21日這天的早上微信中會收 到這樣一條信息
(下圖),終於不用再擔心遺忘什麼重要工作了。
有了這個小教程,再也不用害怕忘記事了,這真的是非常的好用,相信試過之後你就會愛上。喜歡的小伙伴記得點贊收藏,不懂
記得評論留言,看見就會回噢!!