Foros del Web » Programando para Internet » PHP »

exportar con phpexcel no funciona en mi servidor

Estas en el tema de exportar con phpexcel no funciona en mi servidor en el foro de PHP en Foros del Web. Buenos dias tengo un problema con la exportacion de archivos excel desde mi servidor, cuando lo hago de manera local (utilizo xammp) funciona, descarga un ...
  #1 (permalink)  
Antiguo 20/02/2015, 09:22
 
Fecha de Ingreso: noviembre-2010
Mensajes: 105
Antigüedad: 14 años, 1 mes
Puntos: 0
Exclamación exportar con phpexcel no funciona en mi servidor

Buenos dias tengo un problema con la exportacion de archivos excel desde mi servidor, cuando lo hago de manera local (utilizo xammp) funciona, descarga un archivo excel,(aunque la ultima vez me salio una advertencia), pero desde el servidor solo me imprime datos codificados, no me descarga ningun archivo ni nada, este es el codigo:
que podria estar mal

Código PHP:

<?php 
include ("conexiondb.php");
require(
'Classes/PHPExcel.php');
include 
'Classes/PHPExcel/IOFactory.php';
$export=$_POST['exportar'];
$link=Conectarse();
if(
$export=="exportar"){
    
//presionaron el boton de exportar a excel
    
$sqlBuscar mysql_query("SELECT numdoc,nombres,apellidos,pais,ciudad,telefono,celular,mail,nombrecat,laboratorio,factura,valor from registros",$link);
    
    
$totalRows mysql_num_rows($sqlBuscar);
    echo 
"Se imprimiran  ".$totalRows."  Resultados";
    if( 
$totalRows 0) {
        require_once(
'Classes/PHPExcel.php');
        
$objPHPExcel= new PHPExcel();
        
$i=3;
        while(
$totalRows mysql_fetch_object($sqlBuscar)){
                
                
$objPHPExcel->setActiveSheetIndex(0)
                ->
setCellValue('A'.$i,$row->numdoc)
                ->
setCellValue('B'.$i,$row->nombres)
                ->
setCellValue('C'.$i,$row->apellidos)
                ->
setCellValue('D'.$i,$row->pais)
                ->
setCellValue('E'.$i,$row->ciudad)
                ->
setCellValue('F'.$i,$row->telefono)
                ->
setCellValue('G'.$i,$row->celular)
                ->
setCellValue('H'.$i,$row->mail)
                ->
setCellValue('I'.$i,$row->nombrecat)
                ->
setCellValue('J'.$i,$row->laboratorio)
                ->
setCellValue('K'.$i,$row->factura)
                ->
setCellValue('L'.$i,$row->valor);
                
$i++;
            }
//fin while
            
$objPHPExcel->getActiveSheet()->setCellValue('A1','Identificacion');
            
$objPHPExcel->getActiveSheet()->setCellValue('B1','Nombres');
            
$objPHPExcel->getActiveSheet()->setCellValue('C1','Apellidos');
            
$objPHPExcel->getActiveSheet()->setCellValue('D1','Pais');
            
$objPHPExcel->getActiveSheet()->setCellValue('E1','Ciudad');
            
$objPHPExcel->getActiveSheet()->setCellValue('F1','Telefono');
            
$objPHPExcel->getActiveSheet()->setCellValue('G1','Celular');
            
$objPHPExcel->getActiveSheet()->setCellValue('H1','Correo');
            
$objPHPExcel->getActiveSheet()->setCellValue('I1','Categoria');
            
$objPHPExcel->getActiveSheet()->setCellValue('J1','Laboratorio');
            
$objPHPExcel->getActiveSheet()->setCellValue('K1','Factura');
            
$objPHPExcel->getActiveSheet()->setCellValue('L1','Valor');
    
        }
//fin rows
    //    $f=date("Y-m-d");
    //    echo $f;
        
header('Content-Type: application/vnd.ms-excel');
     
//   $fecha01='Reporte.xls';
        
header('Content-Disposition: attachment;filename="reporte.xlsx"');
        
header('Cache-Control: max-age=0');
        
$objPHPExcel->getActiveSheet()->setTitle('Reporte');
        
$objWriter=PHPExcel_IOFactory::createWriter($objPHPExcel,'Excel2007');
        
$objWriter->save('php://output');
        exit;
    }else{
        
        echo 
"no se ha exportado nada";
        
        }
?>
agradezco cualquier ayuda....
  #2 (permalink)  
Antiguo 20/02/2015, 09:38
Avatar de hhs
hhs
Colaborador
 
Fecha de Ingreso: junio-2013
Ubicación: México
Mensajes: 2.995
Antigüedad: 11 años, 5 meses
Puntos: 379
Respuesta: exportar con phpexcel no funciona en mi servidor

La librería tiene varios ejemplos para forzar la descarga, checa la documentación: https://github.com/PHPOffice/PHPExce...velop/Examples
__________________
Saludos
About me
Laraveles
A class should have only one reason to change.
  #3 (permalink)  
Antiguo 20/02/2015, 09:48
 
Fecha de Ingreso: noviembre-2010
Mensajes: 105
Antigüedad: 14 años, 1 mes
Puntos: 0
Exclamación Respuesta: exportar con phpexcel no funciona en mi servidor

Ok le he dado un vistazo pero no parece tener nada diferente...igual probare e informare el resultado
  #4 (permalink)  
Antiguo 20/02/2015, 11:00
 
Fecha de Ingreso: noviembre-2010
Mensajes: 105
Antigüedad: 14 años, 1 mes
Puntos: 0
Exclamación Respuesta: exportar con phpexcel no funciona en mi servidor

Bueno pude descargar el archivo como excel...sirvio la documentacion...lo que pasa ahora es que el archivo baja...pero me sale una advertencia cuando quiero verlo o abrirlo que dice:
Código:
Excel no puede abrir el archivo 'nombrearchivo-xlsx' porque el formato o la extension den este no son validos. Compruebe que el archivo no se ha dañado y que la extension del mismo coincide con el formato de archivo
ahora que sera???
  #5 (permalink)  
Antiguo 20/02/2015, 11:18
Avatar de hhs
hhs
Colaborador
 
Fecha de Ingreso: junio-2013
Ubicación: México
Mensajes: 2.995
Antigüedad: 11 años, 5 meses
Puntos: 379
Respuesta: exportar con phpexcel no funciona en mi servidor

no sera que nombrearchivo-xlsx tiene que ser nombrearchivo.xlsx ?
__________________
Saludos
About me
Laraveles
A class should have only one reason to change.
  #6 (permalink)  
Antiguo 20/02/2015, 12:14
Avatar de supersiana  
Fecha de Ingreso: diciembre-2014
Mensajes: 14
Antigüedad: 10 años
Puntos: 0
Respuesta: exportar con phpexcel no funciona en mi servidor

Si no me equivoco, creo que haces referencia a una variable que no existe.
En la parte del código que te copio:

Código:
   $totalRows = mysql_num_rows($sqlBuscar);
    echo "Se imprimiran  ".$totalRows."  Resultados";
    if( $totalRows > 0) {
        require_once('Classes/PHPExcel.php');
        $objPHPExcel= new PHPExcel();
        $i=3;
        while($totalRows = mysql_fetch_object($sqlBuscar)){
                
                $objPHPExcel->setActiveSheetIndex(0)
                ->setCellValue('A'.$i,$row->numdoc)
                ->setCellValue('B'.$i,$row->nombres)
                ->setCellValue('C'.$i,$row->apellidos)
                ->setCellValue('D'.$i,$row->pais) 
                // .... aquí continua el código
En la línea:
while($totalRows = mysql_fetch_object($sqlBuscar)){

Debería decir:
while($row = mysql_fetch_object($sqlBuscar)){

Para que luego el sistema pueda encontrar el valor del arreglo en las líneas de código:
->setCellValue('C'.$i,$row->xxxxxx)

----------------------------

¿Ayudé o compliqué?
  #7 (permalink)  
Antiguo 20/02/2015, 12:17
Avatar de supersiana  
Fecha de Ingreso: diciembre-2014
Mensajes: 14
Antigüedad: 10 años
Puntos: 0
Respuesta: exportar con phpexcel no funciona en mi servidor

Por otro lado, yo trabajo también trabajo con un servidor local (WAMP) y, por otro lado, con un servidor online.

Cuando intenté por primera vez hacer la exportación en forma local, me funcionó.
Al subirlo al hosting me tiró error.
¿La causa? La base de datos del host todavía no tenía datos, y eso arrojaba el error.
Apenas le cargué un dato, funcionó perfectamente.

Saludos!

Etiquetas: fecha, mysql, phpexcel, registro, select, servidor, sql
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 11:03.