1. 程式人生 > >類似於c語言讀取檔案進行解析

類似於c語言讀取檔案進行解析

        $log_file_name = 'D:/static/develop/kuai_zhi/acagrid.com/public/Logs/'.date('Ym').'/'.date('d').'_error.log';
    
        //$log_file_name = 'D:/static/develop/kuai_zhi/acagrid.com/public/Logs/201701/19_error.log';
 
         
        if(!file_exists($log_file_name)) return;

        
        $handle = fopen($log_file_name,'rb');
         if (FALSE === $handle) {
             exit("Failed to open stream to URL");
         }
         
//        $stream = fread($handle, $length);//從檔案當前指標位置,往後讀取n個位元組長度

         //重置檔案指標的位置。指定指標的位置,指標位置修改後。讀取檔案,後面是從這個位置開始讀取了
         //fseek($handle,105);

         //fgets表示每次讀取檔案的一行


         $error_log_array = [];
         while(  ($line = fgets($handle) )  !==false){
             //每次讀取一行
             
             //匹配出現[1],tp日誌中用這種表示致命錯誤型別
             if(preg_match("/\[1\]/", $line)){
                 $error_log_array[] = $line;
             }
             
         }
         
         fclose($handle);


需要注意的幾個點:

1、如果是使用fwrite,注意避免將原來檔案的內容清空掉了。關鍵是fopen的開啟方式。r或者w。

如果使用追加方式則是a標記。

2、fopen的時候,注意判斷是否成功開啟檔案。避免使用feof的時候進入死迴圈。因為這個函式,當傳入進去不是指標,則這個函式永遠會返回false

feof的本意是:判斷是否為檔案結尾。如果是結尾,則返回true。不是結尾返回false。如果恰好傳入非法的指標,那麼永遠不是檔案結尾了,一直返回

false。

feof()函式,當傳入進去的不是指標型別的時候,使用如下判斷會出現死迴圈

while(!feof($fp)){

}


3、fread和fgets。讀取檔案一行一行讀取,則使用fgets。不是按照行讀取,則使用fread()讀取。

     要注意這一點細節:如果沒有更多的內容,則返回false,也就是兩種情況,如果裡面的內容為空。也會返回false。當讀取到檔案的結尾的時候,這兩個函式也是返回false(難怪我們使用feof()使得我們不會發現這個細節,因為這個函式已經幫助我們判斷檔案結尾了)

4、使用追加方式(即a標記)開啟檔案,要注意,這種方式下,無法讀取檔案內容的,只能往裡面寫入檔案。所以針對這個控制代碼進行fread()是會得到false的

總結是,如果只是僅僅讀取檔案的內容,就只用讀的方式開啟,如果是寫入新內容進去,則用a的方式開啟

現在明白,為什麼要分多種模式進行區分了。以前覺得沒有用。現在看來,開啟的檔案方式決定了,你能夠針對檔案做什麼(新增新內容還是讀取內容。)