将数据从mysql导出到ms-excel


exporting data from mysql to ms excel

我有以下代码,我正在使用这些代码将数据从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格式——迟早你会遇到可怕的兼容性问题)。