php - 使用 PHP 和 mySQL 从网络搜索创建可下载的 CSV

标签 php mysql export-to-csv

我正在尝试创建一个可供用户下载的 CSV 文件,但不会将数据永久保存在服务器上。

我在此页面使用 mySQL 和 PHP。我以正确的格式获取数据以在网页上显示(“回显”),但无法生成/下载文件...也许我遗漏了某些内容或在错误的位置查找,但任何帮助都会很棒!

我一直在尝试几个我自己的脚本和我发现的其他脚本,但我目前拥有的脚本如下:

$file = 'export';
$colresult = mysql_query("SHOW COLUMNS FROM ".$tbl_name.""); 

if (mysql_num_rows($colresult) > 0) {  
while ($row = mysql_fetch_assoc($colresult)){   
$csv_output .= $row['Field'].", ";   $i++;  } } $csv_output .= "\n";   

$csvresult = mysql_query($sql); 

while ($rowr = mysql_fetch_row($csvresult)) {  
for ($j=0;$j<$i;$j++) {   $csv_output .= $rowr[$j].", ";  
}  

$csv_output .= "\n"; }   
$filename = $file."_".date("Y-m-d_H-i",time()).".csv"; 
header("Content-type: application/csv"); 
header("Content-disposition: attachment;filename=".$filename.".csv"); 
readfile("../documents/csv/".$filename.".csv");

$fp = fopen($filename, 'w');
foreach($csvret as $csvret){
fputcsv($fp, $csvret);
}

print $csv_output; 
print $filename; 

谢谢!

最佳答案

您需要传递一些 header 以强制网络浏览器将文件识别为“可下载”:

<?php

header('Content-Description: File Transfer');
header("Content-Type: application/csv"); 
header('Content-Disposition: attachment; filename="'.basename($filename).'"');
header('Content-Transfer-Encoding: binary');
header('Connection: Keep-Alive');
header('Expires: 0');
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
header('Pragma: public');
header('Content-Length: ' . filesize($filename));

readfile($filename);
exit;

只需添加该代码来代替:

print $csv_output; 
print $filename; 

关于php - 使用 PHP 和 mySQL 从网络搜索创建可下载的 CSV,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15505430/

相关文章:

php - foreach、array_map 与 lambda 和 array_map 与静态函数的性能

php - 如何获取通过 drupal hook_menu 发送的多个参数

mysql - 主键 UUID 触发器

mysql - 如何找到一个确切的单词而不是单词的一部分?

javascript - csv export with symbol # as content 导出结束

javascript - 在不断重新加载的页面上保持选定的切换/选项卡打开

php - 无法从 SQL 结果 php 获取实际值

mySQL:使用 'max' 时获取行的其余数据

c# - 将图像导出为 CSV

view - 如何在 SQL Server 2008 R2 Management Studio 中从 'View' 复制带有 header 的结果