我有以下代码,我正在使用这些代码将数据从mysql数据库导出到microsoft excel
$result = $this->db->query($sql);
$num_fields = mysql_num_fields($result);
$header = "";
for($i = 0; $i < $num_fields; $i++ )
{
$header .= mysql_field_name($result,$i)."'t";
}
$data = "";
while($row = mysql_fetch_row($result))
{
$line = '';
foreach($row as $value)
{
if((!isset($value)) || ($value == ""))
{
$value = "'t";
}
else
{
$value = str_replace( '"' , '""' , $value );
$value = '"' . $value . '"' . "'t";
}
$line .= $value;
}
$data .= trim( $line ) . "'n";
}
/*if($code=="M"||$code=='m'){
$value="'n Total 't $total 't";
$data .=trim($value)."'n";
}*/
$data = str_replace("'r" , "" , $data);
if ($data == "")
{
$data = "'n No Record Found!n";
}
header("Cache-Control: ");
header("Content-type: application/octet-stream");
header("Content-Disposition: attachment; filename='"$label.xls'"");
header("Pragma: ");
header("Expires: 0");
print "$header'n$data";
其中$result是一个mysql资源。
当我运行该程序时,在打开之前,excel会发出警告"您试图打开的文件filename.xls的格式与扩展名指定的格式不同,请在打开之前验证该文件是否已损坏并且来自可信来源。您想现在打开该文件吗?"
我被困了,因为在接受打开文件后,我看到了我需要的数据,我想要的是一种使发送的数据格式与xls扩展格式匹配的方法。我该怎么办?。我正在使用msoffice 2007
如果要生成真实的Excel文件,请使用PHPExcel。
您的代码生成一个制表符分隔的ascii文件,而不是您在标题中声称的XLS文件。
返回正确的mimetype("Content-Type:text.csv")和适当的文件扩展名(例如${label}.txt),MSEscel将停止抱怨。
(注意,我会远离任何编写本地MSExcel文件的东西——即使使用MS的"开放"xaml格式——迟早你会遇到可怕的兼容性问题)。