當(dāng)我們遇到文本文件體積很大時(shí),比如超過幾十M甚至幾百M(fèi)幾G的大文件,用記事本或者其它編輯器打開往往不能成功,因?yàn)樗麄兌夹枰盐募?nèi)容全部放到內(nèi)存里面,這時(shí)就會(huì)發(fā)生內(nèi)存溢出而打開錯(cuò)誤,遇到這種情況我們可以使用PHP的文件讀取函數(shù)file_get_contents()進(jìn)行分段讀取。
函數(shù)說明
string file_get_contents ( string $filename [, bool $use_include_path [, resource $context [, int $offset [, int $maxlen ]]]] )
和 file() 一樣,只除了 file_get_contents() 把文件讀入一個(gè)字符串。將在參數(shù) offset 所指定的位置開始讀取長(zhǎng)度為 maxlen 的內(nèi)容。如果失敗,file_get_contents() 將返回 FALSE。
file_get_contents() 函數(shù)是用來將文件的內(nèi)容讀入到一個(gè)字符串中的首選方法。如果操作系統(tǒng)支持還會(huì)使用內(nèi)存映射技術(shù)來增強(qiáng)性能。
應(yīng)用:
$str = $content=file_get_contents("2.sql",FALSE,NULL,1024*1024,1024);
echo $str;
如果針對(duì)較小文件只是希望分段讀取并以此讀完可以使用fread()函數(shù)
$fp=fopen('2.sql','r');
while (!feof($fp)){
$str.=fread($fp, filesize ($filename)/10);//每次讀出文件10分之1
//進(jìn)行處理
}
echo $str;