您好,欢迎访问一九零五行业门户网

php读取大文件的1点疑问

php读取大文件的一点疑问
我要分析一个6g的log文件,比对每行文件是否符合我的要求,程序如下
$file_path = 'd:\work\workplace\test\file\system.log';
$file = fopen($file_path, 'r');
$key = md5(0);
$i = 1;
while (!feof($file)) {
$buff = fgets($file);
if ($buff == $key . \r\n)
{
echo find 0 at line {$i}\r\n;
}
$i ++;
}
fclose($file);

我想问下这样性能怎么样吗,不会出现内存泄露或其他问题吧,还有进一步优化的方法吗?
------解决方案--------------------
你需要先将这个文件分割成若干个小文件 
然后循环读取每个小文件即可!
------解决方案--------------------
linux 下 $ split -b 
分割···
------解决方案--------------------
我建议你用fgets时最好制定读取的字符数,不要一行一行的读,6g的文件说不定某一行会很长!
------解决方案--------------------
6g的文本文件……
你咋能整这么大的文件?
日志应该按天或者按周、按月来记,超过一定大小就新建一个文件
应该分成多个文件
------解决方案--------------------
可以,没有问题。就是很费时间
仅就代码而言,可以缩减一点
$file_path = 'd:\work\workplace\test\file\system.log';
$file = fopen($file_path, 'r');
$key = md5(0);
$i = 1;
while ($buff = fgets($file)) {
    if ($buff == $key . \r\n)
    {
        echo find 0 at line {$i}\r\n;
    }
    $i ++;
}
fclose($file);
如果一次读取的多一点(比如1m)可能要快一点。不过算法要复杂些
------解决方案--------------------
做这种东西,不是php的长项
要不搞web的话,还是换其它程序搞吧。
引用:引用:
6g的文本文件……
你咋能整这么大的文件?
日志应该按天或者按周、按月来记,超过一定大小就新建一个文件
应该分成多个文件
我们公司的行为日志,一天6g
其它类似信息

推荐信息