假設(shè)現(xiàn)在有一個(gè)應(yīng)用場(chǎng)景,需要對(duì)文件系統(tǒng)進(jìn)行監(jiān)控,發(fā)生變化時(shí)產(chǎn)生日志,對(duì)新增的文件做一些相應(yīng)的操作。
比如說(shuō)應(yīng)用到我們之前的音樂(lè)高潮提取器:若當(dāng)前文件夾下增加了一個(gè)音樂(lè)文件,監(jiān)控器就調(diào)用音樂(lè)高潮提取器,自動(dòng)提取該音樂(lè)文件的高潮部分。
這樣的監(jiān)控器寫(xiě)起來(lái)也不難,但是很花時(shí)間,有許多情況要考慮。不過(guò)幸好我們是寫(xiě)Python的,有許多輪子可以使用。
1.準(zhǔn)備
開(kāi)始之前,你要確保Python和pip已經(jīng)成功安裝在電腦上噢,如果沒(méi)有,請(qǐng)?jiān)L問(wèn)這篇文章:超詳細(xì)Python安裝指南 進(jìn)行安裝。如果你用Python的目的是數(shù)據(jù)分析,可以直接安裝Anaconda:Python數(shù)據(jù)分析與挖掘好幫手—Anaconda
Windows環(huán)境下打開(kāi)Cmd(開(kāi)始—運(yùn)行—CMD),蘋(píng)果系統(tǒng)環(huán)境下請(qǐng)打開(kāi)Terminal(command+空格輸入Terminal),準(zhǔn)備開(kāi)始輸入命令安裝依賴。
當(dāng)然,我更推薦大家用VSCode編輯器,把本文代碼Copy下來(lái),在編輯器下方的終端運(yùn)行命令安裝依賴模塊,多舒服的一件事?。?a href="http://www.wenjunhu.com/outside?redirect=http://mp.weixin.qq.com/s?__biz=MzI3MzM0ODU4Mg==&mid=2247485849&idx=1&sn=ec098cf67a55bd1d61d4513397434c94&chksm=eb25eb10dc52620682db716d206c18b00bd53c01743729a9dea381e1791566a04a06f1fabca5&scene=21#wechat_redirect" target="_blank">Python 編程的最好搭檔—VSCode 詳細(xì)指南。
在終端輸入以下命令安裝我們所需要的依賴模塊:
pip install watchdog
看到 Successfully installed xxx 則說(shuō)明安裝成功。
2.基本使用
看門狗的使用并不復(fù)雜,請(qǐng)認(rèn)真看以下代碼和注釋:
可以看到代碼中有幾個(gè)關(guān)鍵步驟,
1.配置各項(xiàng)信息;
2.生成事件處理器、監(jiān)控器;
3.注冊(cè)事件處理器、配置目錄、遞歸執(zhí)行(即同時(shí)監(jiān)控子文件夾);
4:啟動(dòng)。
其實(shí),看門狗的observer是基于** threading.Thread
**對(duì)象的,所以observer很多屬性都繼承了 threading.Thread 的屬性。
如果你不帶參數(shù)地運(yùn)行該腳本,就是要監(jiān)控腳本文件所在的文件夾,如果要監(jiān)控其他文件夾,記得運(yùn)行時(shí)帶文件夾的路徑參數(shù),如:
python obserber.py /data/home/ckend/
我們來(lái)試著運(yùn)行看看:
可以看到,我在當(dāng)前文件夾下做的所有操作都被記錄下來(lái)了。接下來(lái)我們就試試怎么自定義一些操作。
3.監(jiān)控文件變化
如果你不知道怎么提取音樂(lè)文件的高潮部分,請(qǐng)看這篇文章:《Python自動(dòng)提取音樂(lè)文件高潮》。
要實(shí)現(xiàn)這樣的功能,我們有幾種方法,一個(gè)是在原來(lái)log的處理器上做一些新增修改,比如多增一個(gè)函數(shù)調(diào)用音樂(lè)高潮提取器。第二個(gè)是重新繼承 FileSystemEventHandler 類,并做相應(yīng)的修改。這里我們還是要保留log的樣式,只是在log的時(shí)候順便提取音樂(lè)高潮,因此采用第一個(gè)方法。
看看** LoggingEventHandler
**源代碼中的 ** on_created
** ,這就是當(dāng)文件創(chuàng)建時(shí)監(jiān)控器的操作:
我們僅需要繼承這個(gè)類并對(duì)** on_created
**進(jìn)行修改,就能完成我們想要的功能:
首先聲明一個(gè)類,繼承 ** LoggingEventHandler
** ,然后重載** on_created
**函數(shù),在這個(gè)函數(shù)中不僅記錄文件事件變化,還要對(duì)mp3文件做一次音樂(lè)高潮提取。最后別忘了,生成事件處理器時(shí)要用我們新的類名。
看看效果,將** 小永遠(yuǎn).mp3
**復(fù)制過(guò)來(lái):
成功監(jiān)控文件變化并提取到音樂(lè)高潮,生成高潮文件。這樣,只要你保持這個(gè)Python進(jìn)程不關(guān)閉,它就會(huì)一直監(jiān)控這個(gè)文件夾,一旦有音樂(lè)文件進(jìn)入,就會(huì)自動(dòng)提取它的音樂(lè)高潮,在linux系統(tǒng)下,可以搭配supervisor使用,非常好用。
-
看門狗
+關(guān)注
關(guān)注
10文章
565瀏覽量
70874 -
監(jiān)控
+關(guān)注
關(guān)注
6文章
2222瀏覽量
55286 -
文件
+關(guān)注
關(guān)注
1文章
569瀏覽量
24775 -
python
+關(guān)注
關(guān)注
56文章
4801瀏覽量
84859
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論