Foros del Web » Programando para Internet » PHP »

tablas de PHP a EXCEL

Estas en el tema de tablas de PHP a EXCEL en el foro de PHP en Foros del Web. Hola, Hice el tutorial que sale en esta página: http://www.webintenta.com/exportar-t...-y-jquery.html A mi me funciono todo perfecto, lo unico es que tengo un valor que viene ...
  #1 (permalink)  
Antiguo 18/02/2010, 09:51
 
Fecha de Ingreso: noviembre-2003
Ubicación: Frente a la PC
Mensajes: 120
Antigüedad: 20 años, 5 meses
Puntos: 0
tablas de PHP a EXCEL

Hola,
Hice el tutorial que sale en esta página: http://www.webintenta.com/exportar-t...-y-jquery.html


A mi me funciono todo perfecto, lo unico es que tengo un valor que viene desde la base de datos de la siguiente forma: 1-2, 2-2, 3-2, etc, q no son fechas, pero cuando abro el documento en excel los coloca como 01-feb, 02-feb, 03-feb, etc y esa celda se coloca en formato de fecha. Como hacer para que no pase esta situacion?

Gracias..
__________________
Sin sombra no hay luz...
  #2 (permalink)  
Antiguo 18/02/2010, 12:30
 
Fecha de Ingreso: febrero-2010
Mensajes: 3
Antigüedad: 14 años, 2 meses
Puntos: 0
Respuesta: tablas de PHP a EXCEL

Cita:
Iniciado por josecarbono Ver Mensaje
Hola,
Hice el tutorial que sale en esta página: [URL="http://www.webintenta.com/exportar-tablas-html-a-excel-con-php-y-jquery.html"]http://www.webintenta.com/exportar-tablas-html-a-excel-con-php-y-jquery.html[/URL]


A mi me funciono todo perfecto, lo unico es que tengo un valor que viene desde la base de datos de la siguiente forma: 1-2, 2-2, 3-2, etc, q no son fechas, pero cuando abro el documento en excel los coloca como 01-feb, 02-feb, 03-feb, etc y esa celda se coloca en formato de fecha. Como hacer para que no pase esta situacion?

Gracias..
excel siempre te tomará ese formato como fecha, dado que predeterminadamente la celda está configurada para hacerlo.
intentá dos cosas:
1) le das formato de texto (en php) antes de volcarlo a excel, con alguna función intrínseca de php.
2) antes del numero colocás el siguiente signo: '
o sea que te quedaría: '1-2, '2-'2, '3-1, etc
me inclino mas por la segunda, que es la mejor cuando trabajás con excel.
  #3 (permalink)  
Antiguo 18/02/2010, 13:08
Avatar de wpersei  
Fecha de Ingreso: septiembre-2006
Ubicación: Bogota
Mensajes: 189
Antigüedad: 17 años, 7 meses
Puntos: 1
Respuesta: tablas de PHP a EXCEL

Funciona pero entonces hace que los archivos de excel sean demasiado pesadoS, lo mas recomendable es utilizar Spreadsheet

saludos
__________________
www.ogallardo.com - Mi blog
  #4 (permalink)  
Antiguo 18/02/2010, 14:17
Avatar de DeeR  
Fecha de Ingreso: diciembre-2003
Ubicación: Santiago
Mensajes: 520
Antigüedad: 20 años, 4 meses
Puntos: 17
Respuesta: tablas de PHP a EXCEL

Estimado

Lo que estas haciendo es imprimir una tabla html y el excel es capaz de interpretar el html como una planilla, pero suceded los problemas que comentas.

Te recomiendo utilizar PEAR:Spreadsheet para generar un fichero Excel real, te adjunto un ejemplo (necesitas pear y spresheet)
Código PHP:
<?php
// Example by deerme.org
$pear "/usr/share/php5/php/";
ini_set("include_path",ini_get("include_path").":$pear");
require_once(
"Spreadsheet/Excel/Writer.php");

function 
data_to_excel$array $name "Hoja" )
{
        
header("Content-type: application/vnd.ms-excel");
        
header("Content-Disposition: attachment; filename=$name.xls");

        
$x = & new Spreadsheet_Excel_Writer();
        
$x->setVersion(8);
        
$s = &$x->addWorksheet$name );

        
$sx 0;
        
$sy 0;
        foreach( 
$array as $k => $r )
        {
                foreach( 
$r as $kk => $c )
                {
                        if ( 
is_int$c ) or is_float$c ) )
                                
$s->write($sx$sy$c);
                        else
                                
$s->writeString($sx$sy$c);
                        
$sy++;
                }
                
$sx++;
                
$sy 0;
        }
        
$x->close();
}


$data[] = array( "Id" "Codigo" "Producto" ,  "Valor" "Stock" "Costo" "YYYY" );
for( 
$i=0;$i<100;$i++ )
{
        
$data[] = array( ($i ) , "00000000".$i "PK1000".$i ,  rand(10000,99999) , rand(1,100) , rand(1000,9999)*0.79 "1-2" );
}
data_to_excel($data);

?>

Etiquetas: excel, tablas
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 16:10.