How to filter the download of a report in Excel by date?

0
  

index.php

<!DOCTYPE html>
<html>
<title>generando RIPS...</title>
 </head>
 <body>
<div>
 <h1>Registros Individuales</h1>
 <div>
 <a href="relacion.php"> Generar reporte de relacion general</a>
</div>
</div>
</body>
</html>
  

export.php

 <?php
if (PHP_SAPI == 'cli')
    die('Este codigo sólo se puede ejecutar desde un navegador Web');

/** Incluye PHPExcel */
require_once 'Classes/PHPExcel.php';
// Crear nuevo objeto PHPExcel
$objPHPExcel = new PHPExcel();

    // Propiedades del documento
$objPHPExcel->getProperties()->setCreator("Trujii")
                             ->setLastModifiedBy("Trujii")
                             ->setTitle("Office 2010 XLSX Documento de prueba")
                             ->setSubject("Office 2010 XLSX Documento de prueba")
                             ->setDescription("Documento de prueba para Office 2010 XLSX, generado usando clases de PHP.")
                             ->setKeywords("office 2010 openxml php")
                             ->setCategory("Archivo con resultado de prueba");

    // Combino las celdas desde A1 hasta E1
$objPHPExcel->setActiveSheetIndex(0)->mergeCells('A1:J1');

$objPHPExcel->setActiveSheetIndex(0)

            ->setCellValue('A2', 'TIPO DOCUMENTO')
            ->setCellValue('B2', 'NUMERO')
            ->setCellValue('C2', 'PRIMER APELLIDO')
            ->setCellValue('D2', 'SEGUNDO APELLIDO')
            ->setCellValue('E2', 'PRIMER NOMBRE')
            ->setCellValue('F2', 'SEGUNDO NOMBRE')
            ->setCellValue('G2', 'EDAD')
            ->setCellValue('H2', 'UNIDAD EDAD')
            ->setCellValue('I2', 'SEXO')
            ->setCellValue('J2', 'ZONA');

    // Fuente de la primera fila en negrita
$boldArray = array('font' => array('bold' => true,),'alignment' => array('horizontal' => PHPExcel_Style_Alignment::HORIZONTAL_CENTER));

$objPHPExcel->getActiveSheet()->getStyle('A1:J2')->applyFromArray($boldArray);  

    //Ancho de las columnas
$objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(30);  
$objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(30);  
$objPHPExcel->getActiveSheet()->getColumnDimension('C')->setWidth(30);  
$objPHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(30);  
$objPHPExcel->getActiveSheet()->getColumnDimension('E')->setWidth(35);
$objPHPExcel->getActiveSheet()->getColumnDimension('F')->setWidth(30);
$objPHPExcel->getActiveSheet()->getColumnDimension('G')->setWidth(30);
$objPHPExcel->getActiveSheet()->getColumnDimension('H')->setWidth(30);
$objPHPExcel->getActiveSheet()->getColumnDimension('I')->setWidth(30);
$objPHPExcel->getActiveSheet()->getColumnDimension('J')->setWidth(30);

    /*Extraer datos de MYSQL*/
    # conectare la base de datos
    $con=@mysqli_connect('localhost', 'root', 'admin123', 'database');
    if(!$con){
        die("imposible conectarse: ".mysqli_error($con));
    }
    if (@mysqli_connect_errno()) {
        die("Connect failed: ".mysqli_connect_errno()." : ". mysqli_connect_error());
    }
    $sql="SELECT * FROM servicio  order by servicio_No";
    $query=mysqli_query($con,$sql);
    $cel=3;//Numero de fila donde empezara a crear  el reporte
    while ($row=mysqli_fetch_array($query)){

        $tipo_Doc=$row['tipo_Doc'];
        $numero=$row['numero'];
        $primer_Apellido=$row['primer_Apellido'];
        $segundo_Apellido=$row['segundo_Apellido'];
        $primer_Nombre=$row['primer_Nombre'];
        $segundo_Nombre=$row['segundo_Nombre'];
        $edad=$row['edad'];
        $unidad_Edad=$row['unidad_Edad'];
        $sexo=$row['sexo'];
        $zona=$row['zona'];


            $a="A".$cel;
            $b="B".$cel;
            $c="C".$cel;
            $d="D".$cel;
            $e="E".$cel;
            $f="F".$cel;
            $g="G".$cel;
            $h="H".$cel;
            $i="I".$cel;
            $j="J".$cel;


            // Agregar datos
            $objPHPExcel->setActiveSheetIndex(0)
            ->setCellValue($a, $tipo_Doc)
            ->setCellValue($b, $numero)
            ->setCellValue($c, $primer_Apellido)
            ->setCellValue($d, $segundo_Apellido)
            ->setCellValue($e, $primer_Nombre)
            ->setCellValue($f, $segundo_Nombre)
            ->setCellValue($g, $edad)
            ->setCellValue($h, $unidad_Edad)
            ->setCellValue($i, $sexo)
            ->setCellValue($j, $zona);


    $cel+=1;
    }

/*Fin extracion de datos MYSQL*/
$rango="A2:$j";
$styleArray = array('font' => array( 'name' => 'Arial','size' => 10),
'borders'=>array('allborders'=>array('style'=> PHPExcel_Style_Border::BORDER_THIN,'color'=>array('argb' => 'FFF')))
);
$objPHPExcel->getActiveSheet()->getStyle($rango)->applyFromArray($styleArray);
// Cambiar el nombre de hoja de cálculo
$objPHPExcel->getActiveSheet()->setTitle('Reporte de servicios');


// Establecer índice de hoja activa a la primera hoja , por lo que Excel abre esto como la primera hoja
$objPHPExcel->setActiveSheetIndex(0);


// Redirigir la salida al navegador web de un cliente ( Excel5 )
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="reporte.xls"');
header('Cache-Control: max-age=0');
// Si usted está sirviendo a IE 9 , a continuación, puede ser necesaria la siguiente
header('Cache-Control: max-age=1');

// Si usted está sirviendo a IE a través de SSL , a continuación, puede ser necesaria la siguiente
header ('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
header ('Last-Modified: '.gmdate('D, d M Y H:i:s').' GMT'); // always modified
header ('Cache-Control: cache, must-revalidate'); // HTTP/1.1
header ('Pragma: public'); // HTTP/1.0

$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');
exit;
?>
    
asked by Cristian Antonio Trujillo Gris 23.07.2018 в 14:37
source

0 answers