我在 PHP 中使用 fputcsv 来输出数据库查询的逗号分隔文件。在 Ubuntu 中在 gedit 中打开文件时,它看起来是正确的 - 每条记录都有一个换行符(没有可见的换行符,但您可以知道每条记录是分开的,在 OpenOffice 电子表格中打开它可以让我正确查看文件。)
但是,我们将这些文件发送到 Windows 上的客户端,在他们的系统上,文件以一大而长的行出现。在 Excel 中打开它,它根本不识别多行。
我在这里阅读了几个非常相似的问题,包括这个,其中包括一个链接到真正信息丰富的Great Newline Schism解释。
不幸的是,我们不能只告诉我们的客户在“更智能”的编辑器中打开文件。他们需要能够在 Excel 中打开它们。是否有任何编程方式来确保添加正确的换行符,以便可以在任何操作系统上的电子表格程序中打开文件?
我已经在使用自定义函数来强制在所有值周围加上引号,因为 fputcsv 对此是有选择性的。我试过做这样的事情:
function my_fputcsv($handle, $fieldsarray, $delimiter = "~", $enclosure ='"'){
$glue = $enclosure . $delimiter . $enclosure;
return fwrite($handle, $enclosure . implode($glue,$fieldsarray) . $enclosure."\r\n");
}
但是当文件在 Windows 文本编辑器中打开时,它仍然显示为一个长行。