我需要快速逐行读取大型 csv 文件,并将字段分区到数组中。csv 文件有 10 万行。
// Example 1, works in 3.5 seconds
if(false !== $handle = fopen("data.csv", "r")) {
while(($data = fgetcsv($handle, 0, ";"))) {
$arData[] = $data;
}
}
// Example 2, works in 0.3 seconds
if(false !== $handle = fopen("data.csv", "r")) {
while(($data = fgets($handle))) {
$arData[] = explode(";", $data);
}
}
Run Code Online (Sandbox Code Playgroud)
为什么速度差异如此严重?或者我做错了什么?
文档说这fgetcsv是一个与 类似的函数fgets,只不过它将结果分割成一个数组。