php - fputcsv 和换行代码

标签 php newline fputcsv

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

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

我在这里阅读了几个非常相似的问题,包括 this one ,其中包括指向真正信息丰富的链接 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 文本编辑器中打开时,它仍然显示为一长行。

最佳答案

// 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);
  }
}

关于php - fputcsv 和换行代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4080456/

相关文章:

php - ZipArchive 类 PHP 安全问题

javascript - (初学者)如何动态修改一个json文件

c# - 搜索换行符 C#.net

jQuery textarea 追加换行行为

java - 测试两者都包含的字符串结果\n

php - 用 laravel Eloquent 地检索所有记录

php - 如何跳过第一行并从 PHP 中的 csv 读取最多五行

php - fopen()/fputcsv() : error

PHP - 将 MySQL 查询导出到 CSV

javascript - Chart.js 未与在线数据库和 php 链接