$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表示每次讀取文件的一行spa
$error_log_array = [];
while( ($line = fgets($handle) ) !==false){
//每次讀取一行
//匹配出現[1],tp日誌中用這種表示致命錯誤類型
if(preg_match("/\[1\]/", $line)){
$error_log_array[] = $line;
}
}
fclose($handle);指針
須要注意的幾個點:
一、若是是使用fwrite,注意避免將原來文件的內容清空掉了。關鍵是fopen的打開方式。r或者w。
若是使用追加方式則是a標記。
二、fopen的時候,注意判斷是否成功打開文件。避免使用feof的時候進入死循環。由於這個函數,當傳入進去不是指針,則這個函數永遠會返回false
feof的本意是:判斷是否爲文件結尾。若是是結尾,則返回true。不是結尾返回false。若是剛好傳入非法的指針,那麼永遠不是文件結尾了,一直返回
false。日誌
feof()函數,當傳入進去的不是指針類型的時候,使用以下判斷會出現死循環get
while(!feof($fp)){it
}stream
三、fread和fgets。讀取文件一行一行讀取,則使用fgets。不是按照行讀取,則使用fread()讀取。date
要注意這一點細節:若是沒有更多的內容,則返回false,也就是兩種狀況,若是裏面的內容爲空。也會返回false。當讀取到文件的結尾的時候,這兩個函數也是返回false(難怪咱們使用feof()使得咱們不會發現這個細節,由於這個函數已經幫助咱們判斷文件結尾了)file
四、使用追加方式(即a標記)打開文件,要注意,這種方式下,沒法讀取文件內容的,只能往裏面寫入文件。因此針對這個句柄進行fread()是會獲得false的
grid
總結是,若是隻是僅僅讀取文件的內容,就只用讀的方式打開,若是是寫入新內容進去,則用a的方式打開
如今明白,爲何要分多種模式進行區分了。之前以爲沒有用。如今看來,打開的文件方式決定了,你可以針對文件作什麼(添加新內容仍是讀取內容。)