我在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文本编辑器中打开文件时,它仍显示为单个长行。
我最终在专家交流上得到了答案。这是起作用的:
function my_fputcsv($handle, $fieldsarray, $delimiter = "~", $enclosure ='"'){ $glue = $enclosure . $delimiter . $enclosure; return fwrite($handle, $enclosure . implode($glue,$fieldsarray) . $enclosure.PHP_EOL); }
用于代替标准fputcsv。