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 = https://www.yisu.com/ask/explode(',', $line); fputcsv($outputFile, $data); } fclose($inputFile); fclose($outputFile); } else { echo "Error opening file."; }
- 如果可能的话,考虑使用更高效的 CSV 处理库,如 spatie/simple-csv,它提供了更好的性能和更多的功能。
请注意,处理大型文件时,确保您的服务器具有足够的内存和处理能力。如果可能的话,将任务分布到多个服务器或使用队列系统来避免资源过载。