阅读量:86
fputcsv() 函数用于将一行数据写入 CSV 文件
要处理大型 CSV 文件,您可以使用以下方法:
- 使用
set_time_limit(0)函数来取消 PHP 脚本的执行时间限制。这将允许脚本运行足够长的时间来处理大型文件。
set_time_limit(0);
- 使用
fread()和fputs()函数逐行读取和写入文件。这样可以避免一次性加载整个文件到内存中。
$inputFile = fopen('large_file.csv', 'r');
$outputFile = fopen('large_file_output.csv', 'w');
if ($inputFile && $outputFile) {
while (!feof($inputFile)) {
$line = fgets($inputFile);
$data = explode(',', $line);
fputcsv($outputFile, $data);
}
fclose($inputFile);
fclose($outputFile);
} else {
echo "Error opening file.";
}
- 如果可能的话,考虑使用更高效的 CSV 处理库,如 spatie/simple-csv,它提供了更好的性能和更多的功能。
请注意,处理大型文件时,确保您的服务器具有足够的内存和处理能力。如果可能的话,将任务分布到多个服务器或使用队列系统来避免资源过载。