1. 程式人生 > 其它 >用Python寫一個微信提醒備忘錄

用Python寫一個微信提醒備忘錄

前言

有沒有小夥伴跟我一樣,最近工作比較繁雜,經常忘事,有時候記了備忘錄結果卻忘記看備忘錄,但是微信是每天都會看的,於

是就想到寫 一個基於微信的提醒系統。總體思路是將待辦事項記錄到線上記事本,通過建立定時任務,每天早上爬取文件中記 錄

的待辦事項,篩選出當日需要處理的事項,併發送到自己微信。

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日這天的早上微信中會收 到這樣一條資訊

(下圖),終於不用再擔心遺忘什麼重要工作了。

有了這個小教程,再也不用害怕忘記事了,這真的是非常的好用,相信試過之後你就會愛上。喜歡的小夥伴記得點贊收藏,不懂

記得評論留言,看見就會回噢!!