使用fputcsv的优点/缺点是什么


What is the advantages/disadvantages of using fputcsv?

以下代码来自fputcsv的文档:

<?php
$time_start = microtime(true);
$list = array (
    array('aaa', 'bbb', 'ccc', 'dddd'),
    array('123', '456', '789'),
    array('"aaa"', '"bbb"')
);
$fp = fopen('file.csv', 'w');
foreach ($list as $fields) {
    fputcsv($fp, $fields);
}
fclose($fp);
$time_end = microtime(true);
$time = $time_end - $time_start;
echo "time is: $time";
?> 
time is: 0.0037028789520264
time is: 0.0036959648132324
time is: 0.0037329196929932

为什么不直接使用下面的代码呢?他们似乎有同样的速度?通过这种方式,您可以控制需要使用什么样的新行,如'n'r'n

<?php
$time_start = microtime(true);
$list = array (
    array('aaa', 'bbb', 'ccc', 'dddd'),
    array('123', '456', '789'),
    array('"aaa"', '"bbb"')
);
$fp = fopen('file.csv', 'w');
foreach ($list as $fields) {
    fwrite($fp, implode(',', $fields) . "'n");
}
fclose($fp);
$time_end = microtime(true);
$time = $time_end - $time_start;
echo "time is: $time";
?> 
time is: 0.0037031173706055
time is: 0.0037119388580322
time is: 0.0036849975585938

免责声明:我不知道我是否使用了太少的字段基准

fputcsv是一个辅助函数。是的,你可以手工做。在引擎盖下可能会有一些滑稽的东西。但是以这种方式实现更容易,并且提高了可读性。您可以直接放入数组,而不必担心转义等问题。