экспорт данных из mysql в ms Excel

#php

#php

Вопрос:

У меня есть следующий код, который я использую для экспорта данных из базы данных 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 "$headern$data"; 
  

где $result — это ресурс mysql.

Когда я запускаю программу, перед открытием Excel выдает предупреждение «файл, который вы пытаетесь открыть, filename.xls формат отличается от указанного расширением, перед открытием убедитесь, что файл не поврежден и получен из надежного источника. Вы хотите открыть файл сейчас?»

Я в затруднительном положении, потому что после согласия на открытие файла я вижу данные, которые мне требуются, я хочу, чтобы формат отправляемых данных соответствовал формату расширения xls. Что мне делать?. Я использую ms office 2007

Комментарии:

1. Я всегда считал, что лучше выполнять эхо-вывод таблицы данных, чем полагаться на новые строки.

Ответ №1:

Если вы хотите создать реальный файл Excel, используйте PHPExcel.

Комментарии:

1. глядя на приведенный мной код, нет ли другого выхода?

2. @Tamseyc — Если вы хотите создать файл для чтения MS Excel, формат которого фактически соответствует формату расширения xls, тогда вам нужно создать настоящий файл BIFF xls… не файл, разделенный табуляцией; и если вы хотите вместо этого создать файл, разделенный табуляцией, используйте встроенную в PHP функцию fputcsv(), а не создавайте ее вручную… это намного проще и чище

Ответ №2:

Ваш код создает ascii-файл, разделенный табуляцией, а не XLS-файл, как вы утверждаете в заголовке.

Верните правильный mimetype («Content-Type: text / csv») и соответствующее расширение файла (например, ${label}.txt), и MSEscel перестанет жаловаться.

(ПРИМЕЧАНИЕ: Я бы держался подальше от всего, что записывает собственные файлы MSExcel — даже используя «открытые» форматы xaml MS — рано или поздно вы столкнетесь с ужасными проблемами совместимости).

Комментарии:

1. Не могли бы вы, пожалуйста, объяснить, что вы подразумеваете под «ужасными проблемами совместимости»… мне, как разработчику одной из тех библиотек, которые записывают собственные файлы MSExcel, было бы полезно знать, чтобы я мог исправить ситуацию.