首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >fputcsv和换行码

fputcsv和换行码
EN

Stack Overflow用户
提问于 2010-11-03 01:35:53
回答 8查看 40.3K关注 0票数 32

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

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

我在这里读到了几个非常相似的问题,包括this one,它包含一个到真正有用的Great Newline Schism解释的链接。

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

因为fputcsv是有选择性的,所以我已经使用了一个自定义函数来强制将所有值括起来。我试过这样做:

代码语言:javascript
复制
function my_fputcsv($handle, $fieldsarray, $delimiter = "~", $enclosure ='"'){

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

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

}

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

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2010-11-17 02:27:52

我最终在experts-exchange上得到了答案;以下是有效的方法:

代码语言:javascript
复制
function my_fputcsv($handle, $fieldsarray, $delimiter = "~", $enclosure ='"'){
   $glue = $enclosure . $delimiter . $enclosure;
   return fwrite($handle, $enclosure . implode($glue,$fieldsarray) . $enclosure.PHP_EOL);
}

用来代替标准的fputcsv。

票数 -3
EN

Stack Overflow用户

发布于 2011-11-01 08:10:16

代码语言:javascript
复制
// 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);
  }
}
票数 42
EN

Stack Overflow用户

发布于 2014-01-23 09:03:25

这是@John Douthat很好的答案的改进版本,保留了使用自定义分隔符和封闭符的可能性,并返回fputcsv的原始输出:

代码语言:javascript
复制
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;
}
票数 26
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4080456

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档