首页 > 解决方案 > fputcsv 生成没有换行符的行

问题描述

这是删除了 SQL 部分的代码完整代码。我希望它开始下载带有数据库数据的 CSV 文件。但是当我 foreach csv 数组时,它出乎意料地以几乎正确的格式打印所有数据,但忽略换行符并放置 ' '(空格)。

$csv = array(
    array('RECID', 'UID', 'Amount', 'Sumbit Date') 
);

while($row = mysql_fetch_row($results)) // SQL query isn't reason 100%
{
    $csv[] = array($row[0], $row[1], $row[2], $row[3]);
}

$fp = fopen('php://output', 'w');

//this part is unexpected
foreach($csv as $line){
    fputcsv($fp, $line);
}

header("Cache-Control:maxage=1");
header("Pragma: public");
header("Content-Type:text\csv; charset=UTF-8" );
header('Content-Disposition: attachment; filename=csv.csv');

fpassthru($fp);

fclose($fp);

如果更改 foreach 循环并逐行调用 fputcsv 元素,则一切都正确。下载开始,CSV 工作正常。

fputcsv($fp, $csv[0]);
fputcsv($fp, $csv[1]);
fputcsv($fp, $csv[2]);

但是,当您尝试使用任何循环遍历数组时,它会忽略换行符并输出没有换行符但使用 ' ' 作为换行符分隔符的数据。Als它不下载它只是在浏览器中打印所有数据。

foreach($csv as $line){
    fputcsv($fp, $line);
}

如何解决此问题,以使我的脚本按预期工作(放置换行符并开始下载)?

标签: phpforeachfputcsv

解决方案


存在未知错误,当​​您逐行放置 fputcsv 时,在哪里编写并不重要,但是,如果您在循环中执行,则循环必须在所有标题之后!

header("Cache-Control:maxage=1");
header("Pragma: public");
header("Content-Type:text\csv; charset=UTF-8" );
header('Content-Disposition: attachment; filename=csv.csv');

for($i = 0; $i < count($csv); $i++){
    fputcsv($fp, $csv[$i]);
}

推荐阅读