0

我正在尝试提供一个动态生成的 csv 文件。出于某种原因,当我获取文件时,数据前面有 18 个空行。我定义的标题和我发送的 csv 数据之间没有任何空格。如果我将数据写入服务器上的文件,它不会得到这些空行。但是,如果我编写文件然后尝试将其提供给用户,则会返回空行。所以我想知道我是否弄乱了标题,或者是否还有另一个我没有想到的问题:

function generate_csv($source_type, $include_unpublished = FALSE) {

   // retrieve data from DB
   ....

   // start up headers
   $csv_name = "$source_type-$data_set-csv_" . date('Y-m-d') . '.csv';
   header('Content-Type: text/x-comma-separated-values');
   header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
   header('Cache-Control: private', false); // required for certain browser
   header('Content-Disposition: attachment; filename="' . $csv_name . '"'); 

   // send csv data
   print $csv_data;

} //end function

免责声明:我在https://drupal.stackexchange.com/questions/27649/extra-empty-rows-when-serving-csv-file提出了这个问题,但它似乎不是特定于drupal的,并且没有那里有很多想法..

4

2 回答 2

6

也许这行“挂起”在输出缓冲区中,这是在一段时间前开始的。这样,您可以设置标题而不会出现旧的“已发送标题”错误,但是无论如何刷新缓冲区时,此内容都会发送到浏览器。

尝试

ob_clean();
print $csv_data;

http://php.net/ob-clean

于 2012-04-06T20:06:55.427 回答
2

您包含的文件一定有问题。php 结束标记后的每个空格多于一个换行符?>被发送到浏览器。

最好的解决方案是在每个 php 文件中去掉这个结束标签。

其他选项是只删除不必要的新行,或者在提供文件之前缓冲输出并忽略它。

于 2012-04-06T19:43:49.133 回答