一尘不染

fputcsv和换行代码

php

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

但是,我们将这些文件发送到Windows上的客户端,在他们的系统上,文件排成一行,很长。在Excel中打开它,它根本无法识别多行。

我在这里已经阅读了几个非常相似的问题,其中包括这个问题,该问题包含了一个指向内容丰富的Great NewlineSchism解释的链接。

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

我已经在使用自定义函数将所有值都用引号引起来,因为fputcsv是有选择的。我试图做这样的事情:

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

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

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

}

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


阅读 499

收藏
2020-05-29

共1个答案

一尘不染

我最终在专家交流上得到了答案。这是起作用的:

function my_fputcsv($handle, $fieldsarray, $delimiter = "~", $enclosure ='"'){
   $glue = $enclosure . $delimiter . $enclosure;
   return fwrite($handle, $enclosure . implode($glue,$fieldsarray) . $enclosure.PHP_EOL);
}

用于代替标准fputcsv。

2020-05-29