小编sad*_*sdf的帖子

为什么 fgets+explode 比 fgetcsv 更快?

我需要快速逐行读取大型 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,只不过它将结果分割成一个数组。

php csv

1
推荐指数
1
解决办法
1106
查看次数

标签 统计

csv ×1

php ×1