当使用file_get_contents()
读取大文件时,可能会遇到内存限制或脚本执行时间过长的问题
fopen()
和fread()
分块读取文件:$filename = 'largefile.txt';
$bufferSize = 8192; // 每次读取的字节数,可根据需要调整
$handle = fopen($filename, 'r');
if ($handle) {
while (!feof($handle)) {
$data = fread($handle, $bufferSize);
// 处理数据(例如,写入另一个文件或进行其他操作)
echo $data;
}
fclose($handle);
}
SplFileObject
类按行读取文件:$filename = 'largefile.txt';
$file = new SplFileObject($filename, 'r');
while (!$file->eof()) {
$line = $file->fgets();
// 处理每一行数据(例如,写入另一个文件或进行其他操作)
echo $line;
}
fgetcsv()
函数:$filename = 'largefile.csv';
$handle = fopen($filename, 'r');
if ($handle) {
while (($row = fgetcsv($handle)) !== false) {
// 处理每一行数据(例如,写入另一个文件或进行其他操作)
print_r($row);
}
fclose($handle);
}
使用这些方法,你可以在不消耗大量内存的情况下读取大文件。请注意,这些示例仅用于演示目的,你可能需要根据实际需求对代码进行修改。