1- Realizamos la descarga de la librería externa PHPSpreadSheet sin composerhttps://php-download.com/downloads/phpoffice/phpspreadsheet/1.8.2.0/phpoffice_phpspreadsheet_1.8.2.0_require.zip
2- Luego procedemos a cargar la librería externa en el scriptcase: https://www.youtube.com/watch?v=nPiAVJZBbq8podemos guiarnos de este video si aun no sabemos como utilizar las librerías externas en scriptcase
3- En nuestro caso la librería que vamos a utilizar se llama PHP
4- Si ingresamos a ella podremos ver nuestras carpetas cargadas
5-Luego procedemos a utilizar nuestra librería en una aplicaciónblank
6- En el caso de lasllamadas de las clases a utilizar de la librería, el scriptcaseutiliza de la siguiente manera
- Si la clase se encuentra en \PhpOffice\PhpSpreadsheet\src\Spreadsheet.php entoncespara utilizar en el scriptcase se debe realizar\PhpOffice\PhpSpreadsheet\Spreadsheet();
Ejemplo de código para utilizar el SpreadSheet
include sc_url_library("prj","PHP","vendor/autoload.php");
$documento= new \PhpOffice\PhpSpreadsheet\Spreadsheet();
$documento
->getProperties()
->setCreator("Prueba")
->setLastModifiedBy('JuanAquino') // última vez modificado por
->setTitle('Miprimer documento creado con PhpSpreadSheet')
->setSubject('Elasunto')
->setDescription('Estedocumento fue generado para prueba')
->setKeywords('etiquetas opalabras clave separadas por espacios')
->setCategory('Lacategoría');
$nombreDelDocumento= "Mi primer archivo.xlsx";
header('Content-Type:application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition:attachment;filename="' . $nombreDelDocumento . '"');
header('Cache-Control:max-age=0');
#Como ya hay una hoja por defecto, la obtenemos, no la creamos
$hojaDeProductos= $documento->getActiveSheet();
$hojaDeProductos->setTitle("Productos");
#Escribir encabezado de los productos
//$encabezado=["id","nombre","apellido","edad","nacionalidad","profesion","sexo","nacimiento"];
$encabezado=["id","nombre","apellido","edad","sexo","fechaNacimiento0","nacionalidad"];
#El último argumento es por defecto A1 pero lo pongo para que seexplique mejor
$hojaDeProductos->fromArray($encabezado,null, "A1");
//$consulta= "SELECT id, nombre, apellido, edad, nacionalidad, profesion,sexo, nacimiento FROM dbo.tabla2";
$consulta= "SELECT id, nombre, apellido, edad, sexo, fechaNacimiento0,nacionalidad FROM dbo.prueba";
sc_select(ds,$consulta);
//var_dump({ds});
#Comenzamos en la 2 porque la 1 es del encabezado
$numeroDeFila= 2;
$producto= {ds};
foreach($productoas $key => $valor)
{
$id= $valor['id'];
$nombre = $valor['nombre'];
$apellido = $valor['apellido'];
$edad = $valor['edad'];
$nacionalidad= $valor['nacionalidad'];
$profesion= $valor['profesion'];
$sexo = $valor['sexo'];
$fechaNacimiento = $valor['nacimiento'];
#Escribirlos en el documento
$hojaDeProductos->setCellValueByColumnAndRow(1,$numeroDeFila, $id);
$hojaDeProductos->setCellValueByColumnAndRow(2,$numeroDeFila, $nombre);
$hojaDeProductos->setCellValueByColumnAndRow(3,$numeroDeFila, $apellido);
$hojaDeProductos->setCellValueByColumnAndRow(4,$numeroDeFila, $edad);
$hojaDeProductos->setCellValueByColumnAndRow(5,$numeroDeFila, $nacionalidad);
$hojaDeProductos->setCellValueByColumnAndRow(6,$numeroDeFila, $profesion);
$hojaDeProductos->setCellValueByColumnAndRow(7,$numeroDeFila, $sexo);
$hojaDeProductos->setCellValueByColumnAndRow(8,$numeroDeFila, $fechaNacimiento);
$numeroDeFila++;
}
$writer= PhpOffice\PhpSpreadsheet\IOFactory::createWriter($documento,'Xlsx');
$writer->save('php://output');
exit;