Foros del Web » Programando para Internet » PHP »

problema al exportar a excel

Estas en el tema de problema al exportar a excel en el foro de PHP en Foros del Web. Saludos, tengo el siguiente problema.... genero un reporte en excel, el archivo se genera sin mayor problema, sm embargo al tratar de abrir el archivo ...
  #1 (permalink)  
Antiguo 16/07/2008, 14:09
 
Fecha de Ingreso: julio-2008
Mensajes: 6
Antigüedad: 15 años, 9 meses
Puntos: 0
problema al exportar a excel

Saludos, tengo el siguiente problema.... genero un reporte en excel, el archivo se genera sin mayor problema, sm embargo al tratar de abrir el archivo en excel me muestra el siguiente mensaje:

The file you are trying to open, 'reporte.xls' is in a different format than specified by the file extension. Verify that the file is not corrupted and is from a trusted source before opening the file. Dou you want to open the file now?


Al decirle que si el archivo lo abre sin mayor problema de formato ni nada... el problema esque no quieren que aparezca este mensaje.


Lo primero que se me ocurrio fue que el problema esque abro el archivo en excel 200, por lo que trate cambiandole la extension al archivo generado:

de: header("Content-Disposition: attachment; filename=reporte.xls");

a: header("Content-Disposition: attachment; filename=reporte.xlsx");

pero no funciono, luego de buscar encontre esta pagina:

http://www.grinn.net/blog/dev/2008/06/file-you-are-trying-to-open-is-in.html

sin embargo quisiera ver si alguien me podria ayudar a evitar que aparezca dicho mensanje modificando algo del codigo.


Pongo todo el codigo... saludos...

---------------------------------------------------------------------------------------------------------
<?php
session_name("loginUsuario");
session_start();
require_once('Connections/Sobrecarga.php');
mysql_select_db($database_Sobrecarga, $Sobrecarga);

header("Content-type: application/vnd.ms-excel");
header("Content-Disposition: attachment; filename=reporte.xls");
header("Pragma: no-cache");
header("Expires: 0");

if ($_SESSION["id_centro"]==1){
$rs_pacientes_total = mysql_query("SELECT * FROM pacientes");
} else {
$rs_pacientes_total = mysql_query("SELECT * FROM pacientes where id_centro= '".$_SESSION["id_centro"]."'");
}
echo "<table border=1>\n";
echo "<tr>\n";
echo "<th bgcolor='#FFFF99'>Clave</th>\n";
echo "<th bgcolor='#FFFF99'>Nombre</th>\n";
echo "<th bgcolor='#FFFF99'>Sexo</th>\n";
echo "<th bgcolor='#FFFF99'>Fecha de nacimiento</th>\n";
echo "<th bgcolor='#FFFF99'>Fecha de diagnostico</th>\n";
echo "<th bgcolor='#FFFF99'>Diagnostico LAM</th>\n";
echo "<th bgcolor='#FFFF99'>Diagnostico SMD</th>\n";
echo "<th bgcolor='#FFFF99'>Tpo de tratamiento</th>\n";
echo "<th bgcolor='#FFFF99'>Num. Transfusiones</th>\n";
echo "<th bgcolor='#FFFF99'>Centro</th>\n";
echo "</tr>\n";
if ($row_pacientes_total = mysql_fetch_array($rs_pacientes_total)){
$color='#FFFFFF';
do {
$rs_centros = mysql_query("SELECT * FROM centros WHERE id_centro='".$row_pacientes_total["id_centro"]."'", $Sobrecarga);
$row_centros = mysql_fetch_array($rs_centros);
$result_diagnostico= mysql_query("SELECT * FROM diagnostico WHERE id_diagnostico= '".$row_pacientes_total['id_diagnostico']."'", $Sobrecarga);
$row_pacientes_diagnostico = mysql_fetch_array($result_diagnostico);
$result_lam= mysql_query("SELECT descripcion FROM lam WHERE id_lam= '".$row_pacientes_diagnostico['id_lam']."'", $Sobrecarga);
$row_pacientes_lam = mysql_fetch_array($result_lam);
$result_smd= mysql_query("SELECT descripcion FROM smd WHERE id_smd= '".$row_pacientes_diagnostico['id_smd']."'", $Sobrecarga);
$row_pacientes_smd = mysql_fetch_array($result_smd);
$result_tipo_tratamiento= mysql_query("SELECT descripcion FROM tipo_tratamiento WHERE id_tipo_tratamiento= '".$row_pacientes_diagnostico['id_tipo_tratamiento']."'", $Sobrecarga);
$row_pacientes_tipo_tratamiento = mysql_fetch_array($result_tipo_tratamiento);

echo "<tr>\n";
echo "<td bgcolor=$color><font color='#003399'><b>".$row_centros['clv_centro'].$row_pacientes_total['id_paciente']."</b></font></td>\n";
echo "<td bgcolor=$color><font color=black>".$row_pacientes_total['iniciales_paciente']."</font></td>\n";
if ($row_pacientes_total['sexo']==0){
echo "<td bgcolor=$color><font color=black>Masculino</font></td>\n";
} else{
echo "<td bgcolor=$color><font color=black>Femenino</font></td>\n";
}
echo "<td bgcolor=$color><font color=black><div align='left'>".$row_pacientes_total['fecha_nacimiento']."</font></td>\n";
echo "<td bgcolor=$color><font color=black><div align='left'>".$row_pacientes_total['fecha_diagnostico']."</font></td>\n";
echo "<td bgcolor=$color><font color=black>".$row_pacientes_lam['descripcion']."</font></td>\n";
echo "<td bgcolor=$color width=380><font color=black>".$row_pacientes_smd['descripcion']."</font></td>\n";
echo "<td bgcolor=$color><font color=black>".$row_pacientes_tipo_tratamiento['descripcion']."</font></td>\n";
echo "<td bgcolor=$color><font color=black><div align='left'>".$row_pacientes_total['num_transfusiones']."</font></td>\n";
echo "<td bgcolor=$color><font color=black>".$row_centros['descripcion']."</font></td>\n";
echo "</tr>\n";

if ($color == '#FFFFFF') {
$color = '#ECECFF';
} else {
$color = '#FFFFFF';
}
} while ($row_pacientes_total = mysql_fetch_array($rs_pacientes_total));
}
?>
-------------------------------------------------------------------------------------------------
  #2 (permalink)  
Antiguo 16/07/2008, 17:41
Avatar de kaninox  
Fecha de Ingreso: septiembre-2005
Ubicación: In my House
Mensajes: 3.597
Antigüedad: 18 años, 7 meses
Puntos: 49
Respuesta: problema al exportar a excel

y con que office quieres abrir el excel de por si el formato deberia seria ser .xls y ya
pero no se si estas tratando de abrir con el nuevo 2007 no se como ira eso, no lo he probado pero como veo que los documentos de 2007 ya no van en versiones anteriores algun problema debe haber....

ahora has tratado de generar un simple txt con los datos y ver que sale...
despues generas el .xls

saludos...
__________________
Gokuh Salvo al mundo. PUNTO!!!!
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 19:43.