PHP

php fputcsv 处理大文件行吗

小樊
81
2024-11-25 02:59:28
栏目: 编程语言

fputcsv() 函数用于将一行数据写入 CSV 文件

要处理大型 CSV 文件,您可以使用以下方法:

  1. 使用 set_time_limit(0) 函数来取消 PHP 脚本的执行时间限制。这将允许脚本运行足够长的时间来处理大型文件。
set_time_limit(0);
  1. 使用 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.";
}
  1. 如果可能的话,考虑使用更高效的 CSV 处理库,如 spatie/simple-csv,它提供了更好的性能和更多的功能。

请注意,处理大型文件时,确保您的服务器具有足够的内存和处理能力。如果可能的话,将任务分布到多个服务器或使用队列系统来避免资源过载。

0
看了该问题的人还看了