fputcsv 和换行代码

2022-08-30 14:09:42

我在PHP中使用fptcsv来输出数据库查询的逗号分隔文件。在Ubuntu的gedit中打开文件时,它看起来是正确的 - 每条记录都有一个换行符(没有可见的换行符,但你可以分辨出每条记录都是分开的,在OpenOffice电子表格中打开它允许我正确查看文件。

但是,我们将这些文件发送到Windows上的客户端,在他们的系统上,该文件以一个大而长的行的形式出现。在Excel中打开它,它根本无法识别多行。

我在这里读到了几个非常相似的问题,包括这个问题,其中包括个链接到真正翔实的Great Newline Schism解释。

不幸的是,我们不能只是告诉我们的客户在“更智能”的编辑器中打开文件。他们需要能够在Excel中打开它们。是否有任何编程方法可以确保添加正确的换行符,以便可以在任何操作系统上的电子表格程序中打开文件?

我已经使用自定义函数来强制引号围绕所有值,因为fptcsv对此是有选择性的。我尝试过做这样的事情:

function my_fputcsv($handle, $fieldsarray, $delimiter = "~", $enclosure ='"'){

        $glue = $enclosure . $delimiter . $enclosure;

    return fwrite($handle, $enclosure . implode($glue,$fieldsarray) . $enclosure."\r\n");

}

但是,当在 Windows 文本编辑器中打开该文件时,它仍然显示为一行长行。


答案 1
// Writes an array to an open CSV file with a custom end of line.
//
// $fp: a seekable file pointer. Most file pointers are seekable, 
//   but some are not. example: fopen('php://output', 'w') is not seekable.
// $eol: probably one of "\r\n", "\n", or for super old macs: "\r"
function fputcsv_eol($fp, $array, $eol) {
  fputcsv($fp, $array);
  if("\n" != $eol && 0 === fseek($fp, -1, SEEK_CUR)) {
    fwrite($fp, $eol);
  }
}

答案 2

这是@John Douthat伟大答案的改进版本,保留了使用自定义分隔符和外壳并返回fptcsv原始输出的可能性:

function fputcsv_eol($handle, $array, $delimiter = ',', $enclosure = '"', $eol = "\n") {
    $return = fputcsv($handle, $array, $delimiter, $enclosure);
    if($return !== FALSE && "\n" != $eol && 0 === fseek($handle, -1, SEEK_CUR)) {
        fwrite($handle, $eol);
    }
    return $return;
}

推荐