Buenas gente!
Cuántas veces nos toca exportar datos que se muestran en un datagrid/advanceddatagrid/olap a excel y siempre repetimos lo mismo, sólo se puede hacer desde backend (bueno, no es del todo cierto ya que con javascript se puede hacer a medias). Pero bueno ahora gracias a una librería que encontré en google code se pueden generar desde AS3 gracias a la clase ByteArray.
El proyecto de google code es: http://code.google.com/p/as3xls/ e intenta portar las especificaciones de las estructuras BIFF a AS3 (estructuras de los archivos excel brindadas por openoffice).
Estado de la librería: Recién acepta excel 2 (BIFF 2) por lo que solo se pueden manejar texto y tipos de datos de columna simple y algo de formulas.
Bueno... para mi trabajo tuve que generar exportaciones a excel de datos que se muestran en un datagrid y por ahora con este nivel de desarrollo de la librería me es suficiente.
Entonce creé un Util para utilizar la librería de forma mas sencilla, veamos como exportar los datos desde un datagrid
Ejemplo en Flex:
Código :
<?xml version="1.0" encoding="utf-8"?> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="vertical"> <mx:Script> <![CDATA[ import com.kcc.tempos.utils.exporter.ExcelExporterUtil; import mx.collections.IViewCursor; import com.as3xls.xls.ExcelFile; import com.as3xls.xls.Sheet; import mx.collections.ArrayCollection; [Bindable] private var flat:ArrayCollection = new ArrayCollection([ {nombre:"Andrés", apellido:"Sanchez"}, {nombre:"Mónica", apellido:"Sanchez"}, {nombre:"Agustina", apellido:"Sanchez"}, {nombre:"Pablo", apellido:"Sanchez"}, {nombre:"Magalí", apellido:"Sanchez"} ]); private function onExportToExcel():void { ExcelExporterUtil.dataGridExporter(this.dg, "prueba_excel.xls"); } ]]> </mx:Script> <mx:DataGrid id="dg" dataProvider="{flat}"> <mx:columns> <mx:DataGridColumn dataField="nombre" headerText="Nombre" /> <mx:DataGridColumn dataField="apellido" headerText="Apellido" /> </mx:columns> </mx:DataGrid> <mx:Button label="Export" click="onExportToExcel();" /> </mx:Application>
Esta no es la única funcionalidad, sino que puede exportar cualquier cosa, un array, arraycollecion, xml, xmllist, etc.
Aca les dejo la clase
Código :
package com.kcc.tempos.utils.exporter { import com.as3xls.xls.ExcelFile; import com.as3xls.xls.Sheet; import flash.errors.IllegalOperationError; import flash.net.FileReference; import flash.utils.ByteArray; import mx.collections.ArrayCollection; import mx.collections.ICollectionView; import mx.collections.IViewCursor; import mx.collections.XMLListCollection; import mx.controls.DataGrid; /** * * Author: Andrés Lozada Mosto * Version: 0.1 * Fecha release: 10/03/2009 * Contacto: [email protected] * * Clase que maneja la exportacion de elementos * a Excel. * * Se utiliza el proyecto http://code.google.com/p/as3xls/ * para la generacion de Excel. * * Se necesita la version 10 de Flash player para realizar el correcto * guardado del archivo sin pasar por backend. * * @example * <code> * private var flat:ArrayCollection = new ArrayCollection([ * {nombre:"Andrés", apellido:"Sanchez"}, * {nombre:"Mónica", apellido:"Sanchez"}, * {nombre:"Agustina", apellido:"Sanchez"}, * {nombre:"Pablo", apellido:"Sanchez"}, * {nombre:"Magalí", apellido:"Sanchez"} * ]); * ExcelExporterUtil.dataGridExporter(this.dg, "prueba_excel.xls"); * </code> * * Lista de funciones * <list> * dataGridExporter: Exporta un datagrid a un excel de forma automatica * export: Exporta un listado de objetos * </list> * */ public class ExcelExporterUtil { public function ExcelExporterUtil() { throw new IllegalOperationError("Class \"ExcelExporterUtil\" is static. You can't instance this"); } //----------------------------- // Public function //----------------------------- /** * * Exporta los datos de un datagrid hacia un Excel. * Toma el dataProvider del mismo y las columnas para su exportacion * * @param dg Referencia al datagrid * @defaultName Nombre default con el que se va a generar el archivo excel * */ static public function dataGridExporter(dg:DataGrid, defaultName:String):void { if (dg == null || dg.dataProvider == null || defaultName == null || defaultName == "") return; var cols:Number = 0; var colsValues:Array = []; var cantCols:Number = dg.columnCount; var fieldT:String; var headerT:String; // armo el listado de headers y variables para cada columna for ( ; cols < cantCols; cols++) { headerT = (dg.columns[cols] as Object).headerText fieldT = (dg.columns[cols] as Object).dataField; if ( fieldT == null || fieldT == "" || headerT == null || headerT == "") continue; colsValues.push({ header:headerT, value:fieldT }); } if ( colsValues.length == 0 ) return; ExcelExporterUtil.export(dg.dataProvider, colsValues, defaultName); } /** * * Export to Excell * * @param obj Objeto simple, XML, XMLList, Array, ArrayCollection o XMLListCollection * que se quiere exportar a excel * @colsValues Listado de objetos que indican cual es el nombre de la columna * y que propiedad del objeto se utiliza para sacar los datos de la columna * {header:"nombre del header", value:"propiedad del objeto que contiene el valor"} * @param defaultName Nombre default con el que se genera el excel * */ static public function export(obj:Object, colsValues:Array, defautlName:String):void { var _dp:ICollectionView = ExcelExporterUtil.getDataProviderCollection(obj); if ( _dp == null ) return; var rows:Number = 0; var cols:Number = 0; var cantCols:Number = colsValues.length; var sheet:Sheet = new Sheet(); sheet.resize(_dp.length, colsValues.length); for ( ; cols < cantCols; cols++) { sheet.setCell(rows, cols, colsValues[cols].header); } cols = 0; rows++; var cursor:IViewCursor = _dp.createCursor(); while ( !cursor.afterLast ) { for (cols = 0 ; cols < cantCols; cols++) { if ( (cursor.current as Object).hasOwnProperty(colsValues[cols].value) ) sheet.setCell(rows, cols, (cursor.current as Object)[colsValues[cols].value]); } rows++; cursor.moveNext(); } var xls:ExcelFile = new ExcelFile(); xls.sheets.addItem(sheet); var bytes:ByteArray = xls.saveToByteArray(); var fr:FileReference = new FileReference(); fr.save(bytes, defautlName); } //----------------------------- // Private function //----------------------------- /** * * A partir de un elemento pasado se genera un ICollectionView * para su correcto recorrido * * @param obj Objeto a convertir a ICollectionView * * * @return referencia a un ICollectionView. * */ static private function getDataProviderCollection(obj:Object):ICollectionView { if ( (obj is Number && isNaN(obj as Number)) || (!(obj is Number) && obj == null)) { return null; } else if ( obj is ICollectionView ) { return obj as ICollectionView; } else if ( obj is Array ) { return new ArrayCollection(obj as Array); } else if ( obj is XMLList ) { return new XMLListCollection(obj as XMLList); } else if ( obj is XML ) { var col:XMLListCollection = new XMLListCollection(); col.addItem(obj); return col; } else if ( obj is Object ) { return new ArrayCollection([obj]); } else { return null; } } } }
Nivel de desarrollo actual de la clase:
- Exporta listas de objetos a un excel
- Exporta un datagrid a un excel
Tareas en desarrollo:
- Testing
------ En entorno Flash
------ Exportacion de XML, XMLList, XMLListCollection
------ Exportaciones directas desde AdvancedDataGrid y OLAPDataGrid
- Implementar BIFF 8 asi se le puede agregar cualquier tipo de multimedia
Saludos y espero que les sirva
¿Sabes SQL? ¿No-SQL? Aprende MySQL, PostgreSQL, MongoDB, Redis y más con el Curso Profesional de Bases de Datos que empieza el martes, en vivo.
Por leobaraldi el 19 de Marzo de 2009
Por Raxiro el 20 de Marzo de 2009
Por andresmaro el 20 de Marzo de 2009
Por Hernan el 20 de Marzo de 2009
Por Otaku RzO el 20 de Marzo de 2009
Felicidades por el tip, te quedo de lujo.
Por leoncitoamx el 21 de Marzo de 2009
Por alexsanchezm el 22 de Marzo de 2009
Saludos y muchas gracias.
Por alfathenus el 25 de Marzo de 2009
Bueno en estos dias estuve refactorizando un poco la clase y quedo asi... fijense q tiene alguna q otra funcionalidad nueva.
(Fijense q cambio el nombre de la clase)
ExcelExport.as
Código :
Bueno, si alguien puede ayudar en probar todas las funcionalidades con mas exhaustividad de las q probe yo, seria de gran ayuda para toda la comunidad.
Test a probar
-Exportar desde: AdvancedDataGrid, OLAPDataGrid, XMLList, XMLListCollection
Desarrollo faltante
-Verficar la correcta internacionalizacion. Que permita generar archivos excel en UTF-8 para los acentos y las ñ.
Avisen si se les ocurre alguna funcionalidad nueva
Saludos!
Por magoisp el 27 de Marzo de 2009
es muy buena esta libreria sin embargo como ya han comentado, no respeta acentos ni la letra ñ, asi que por favor si alguien sabe como solucionar eso que lo comparta con los demas
espero que alguien ya lo haya solucionado y lo publique
saludos
Por alfathenus el 30 de Marzo de 2009
magoisp-blog :
es muy buena esta libreria sin embargo como ya han comentado, no respeta acentos ni la letra ñ, asi que por favor si alguien sabe como solucionar eso que lo comparta con los demas
espero que alguien ya lo haya solucionado y lo publique
saludos
Como andas, si, no acepta la puntuacion clasica española... pero bueno, como nadie aporto... aca les paso la solucion:
En el archivo "ExcelFile.as" de la libreria de excel, en la linea 256, reemplacen este codigo:
Código :
por este nuevo:
Código :
Ahora acepta utf-16, practicamente cualqueir caracter de cualqueir idioma (salvo chino, arabe y esos lenguajes.... si necesitas q soporte eso simplemente cambia el charset y listo).
Espero q les sirva
Saludos!!
PD: voy a ir tratando de agregarle soporte para generar archivos de excels de versiones mas nuevas... pero bueno eso se hara de a poco...
Por magoisp el 02 de Abril de 2009
ya modifique lo que me dijiste y efectivamente ahora si me respeta los acentos y la lertra ñ pero tiene un pequeño defecto
me pone un espacio despues de cada caracter, por ejemplo quiero exportar la palabra Sánchez, y lo que me resulta en la celda de Excel es: "S á n c h e z "....
sabes algo acerca de eso???
espero puedas ayudarme con eso
saludos
Por alfathenus el 03 de Abril de 2009
Saludos!
Por magoisp el 03 de Abril de 2009
si copio varias celdas y las pego en word me lo pone correcto, sin espacios en una tabla, pero si eligo en las opciones de pegado 'conservar solo texto' solo pone la primera letra....
esto es lo mismo para una sola celda, si la copio y la pego en word lo pone correcto, por ejemplo en la celda de Excel aparece algo como esto "D a v i d", entonces selecciono la celda y le doy copiar y la pego en word ya pone "David" pero si le digo consercvar solo texto solo pone "D"... esto es seleccionando la celda, si selecciono el texto que esta dentro de la celda solo pone la primera letra....
esto solo sucede con los campos 'label' porque los numeros estan correctos...
no se como podria enviarte mi archivo xls generado para que lo checaras, igual te enviaria el ExcelFile.as que es donde debe estar el problema...
mi correo es marspiii[a]hotmail.com
espero me haya explicado y me puedas ayudar ....
saludos ...
Por magoisp el 03 de Abril de 2009
ps dejando otro post
parece ser que ya se soluciono el problema que tenia...
en el archivo ExcelFile.as importe la clase File: import flash.filesystem.File;
y en el codigo que modificaste cambie el charset (utf-16) por File.systemCharset, [que en mi caso (Windows Vista) es 'windows-1252' (Europeo occidental)] de la siguiente forma:
var charset:String = File.systemCharset;
espero que al cambiar de SO no haya problema.....
ps si encuentras otra solucion sera bien aceptada
gracias y saludos ;D
Por alfathenus el 04 de Abril de 2009
El unico problema que veo es q la clase File solo esta disponible para AIR, porq lo q no seria la mejor solucion.
Aun no pude ver eso de los espacios q mencionas, en estos dias me voy a fijar, y voy a tratar de arreglar esto junto con otras mejoras q ya tengo en mente (por ej q reconozca los itemrenderers de las columnas y cosas asi).
Saludos y muhcas gracias por la ayuda y si queres agregarle funcionalidades o arreglar algun error me serias de mucha ayuda
Por isantos el 07 de Abril de 2009
por lo de los espacios si quieres puedo pasarte los archivos de excel que me genero para que los cheques tu...
y por otra parte me gustaria ayudar, pero soy algo novato en esto , no se si les maracaba un error al abrir los archivos de excel que decia fin del archivo y nadamas no los cargaba... si es asi la solucion esta aca
http://code.google.com/p/as3xls/issues/detail?id=4
y por ultimo
no se si con esta libreria se pueden formatear las columnas en el archivo de excel a erxportar, algo como ancho de columna, fuente, combinar columnas o algo asi....
si se puede ps haganlo saber jeje
[magoisp-blog]
saludos
Por alfathenus el 07 de Abril de 2009
saludos y muchas gracias por el aporte
Por isantos el 07 de Abril de 2009
si hago algo lo posteo aqui
saludos
Por drakon0 el 14 de Abril de 2009
Me esta dando ese error, no se que se debe ese error, he creado el archivo excel y he puesto el codigo como esta.
Saludos!!
Por alfathenus el 14 de Abril de 2009
Saludos!
Por drakon0 el 14 de Abril de 2009
Por alfathenus el 14 de Abril de 2009
Saludos!
Por Esteban el 15 de Abril de 2009
Gracias!
Por hector el 08 de Mayo de 2009
Gracias por cualquier aporte
Por alfathenus el 09 de Mayo de 2009
Por Luis Gabriel Correa el 12 de Mayo de 2009
He estado consultando y casi todo es basado en otros lenguajes, por lo general php, lo que hacen es mandar los datos a php y realizan la exportación a Excel y después devuelven el archivo a Flex, esto no me parece una buena forma de hacer la exportación.
Si saben de algo cuentan
Por alfathenus el 15 de Mayo de 2009
Saludos!
Por Yaz el 19 de Mayo de 2009
Ya pudimos exportar a excel aunque nos encontramos con otro problema. En un reporte no nos reconoce el getrows, si encontramos solución lo publico.
Gracias
Por alfathenus el 20 de Mayo de 2009
Por alfathenus el 20 de Mayo de 2009
saludos!
Por Mario el 22 de Mayo de 2009
Por Figux el 22 de Mayo de 2009
Por alfathenus el 22 de Mayo de 2009
Te recomiendo igual q utilices el ultimo sdk, el 3.3, es mucho mas estable y corrige muchisimos bus.
(Creo q a lo q vos llamasn Flex 3.0 intestas decir flex builder 3 no???)
@Mario: tenes q entrar a la pag del proyecto en google code y bajarte la libreria q detallo en el tip y luego bajarte las clases que coloque en el tip y listo.... nose si eso te ayude o necesitas algo mas, avisa cualquier cosa y veo si puedo colgar en algun lado un proyecto ya configurado con todas las librerias.
Saludos!
Por Mario el 23 de Mayo de 2009
Por Enrique Sanchez el 25 de Mayo de 2009
Saludos.
Por alfathenus el 26 de Mayo de 2009
Esta noche colgare el proyecto en google code, mientras tanto, le dejo como utilizar las clases.
1. Copiar las clases
2. PAra exportar un datagrid es de la siguiente manera:
Código :
3. Para exportar un grafico seria asi:
Código :
Saludos!
Por Figux el 26 de Mayo de 2009
1061: Call to a possibly undefined method save through a reference with static type flash.net:FileReference. InteresSimple/src/utils ExcelExporterUtil.as
Por Tavo el 27 de Mayo de 2009
PROJECT - PROPERTIES y en la opción de Flex Compiler y abajo aparece la version de flash en la que estas compilando, para usar el .save tienes que tener 10.0.0 y ya con eso debe funcionar
Por Mario el 01 de Junio de 2009
Saludos.
Por Omar el 11 de Junio de 2009
sheet.resize(obj.length+1, colsValues.length);
a la funcion exportToExcel
Por sergestux el 15 de Junio de 2009
ExcelExport.fromGrid(this.dg, "prueba_excel_datagrid.xls");
Pero en la ultima clase que pusiste (la refactorizada) tu definicion la tienes asi:}
static public function fromGrid(grid:*, defaultName:String, params:Object):void
Por lo cual como es de esperarse, me marca el siguien error:
"1136: Incorrect number of arguments. Expected 3. test test.mxml line 31 1245101973562 1814"
Cual es el tercer parametro?. Te comento que la primer clase si trabaja bien.
Por alfathenus el 17 de Junio de 2009
Fijate en la documentacion de la clase, ahi esta especificado q es lo q se le tiene q pasar. es un objeto simple, un Object (en la documentacion se especifica ese objeto), o bien le podes pasar null.
Saludos!
Por Mario el 23 de Junio de 2009
Por alfathenus el 02 de Julio de 2009
Saludos!
Por elBarto el 07 de Julio de 2009
Por alfathenus el 22 de Julio de 2009
El tema es asi.. hay q leer la especificacion de BIFF y ver cuales bytes hay q configurar para q acepte la configuracion de formato...
Tengo algo por ahi hecho para poderle darle color a las celdas, hacer merges de celdas y algo mas, voy a ver cuando tengo tiempo en juntar todo...
Saludos!
Por milton el 29 de Julio de 2009
Por sergestux el 29 de Julio de 2009
Por alfathenus el 30 de Julio de 2009
Por yoni el 12 de Agosto de 2009
el largo del string que sí llega a Excel varía y tampoco lo corta en el primer break de linea o algo asi.
alguien conoce el problema?
Por Fernando el 30 de Septiembre de 2009
if ( fieldT == null || fieldT == "" || headerT == null || headerT == "" )
Que está en el método:
static public function dataGridExporter(dg:DataGrid, defaultName:String):void
Por esta otra linea:
if ( fieldT == null || fieldT == "" || headerT == null || headerT == "" || dg.columns[cols].visible == false)
A medida que vaya viendo otras cosas (formato de celdas, etc) lo iré subiendo.
Saludos.
Por Luis Neira el 24 de Noviembre de 2009
Baje el proyecto de donde me dijiste, luego cree el mxml, luego, cree la función, pero aun así no me funciona. me da este error.
1120: Access of undefined property ExcelExport.
Primero nombraste la clase así ExcelExporterUtil luego ExcelExport. la verdad estoy confundido, porque cree el path en donde puse la clase y la referencio, es mas cuando la trato de usar y comienzo a escribir el autocompletado de Flex me muestra la función, pero despues me reclama como que no la encuentra.
Estoy confundido
Por abraham el 04 de Febrero de 2010
Por Fabian Mejia el 08 de Febrero de 2010
Por jonathanglez el 13 de Febrero de 2010
De antemano muchas gracias por el aporte
La siguiente pregunta tal vez este fuera de este contexto, pero de aqui nacio la necesidad.
Al tratar de implementar el proyecto de exportacion de datos en un datagrid a excel, me marco el error de FILEREFERENCE.SAVE que se menciona mas arriba, lei que es necesario tener el SDK 3.5 .
Al instalar el SDK 3.5 y tratar de abrir el proyecto en mencion no me muestra en modo diseño los controles que tiene la aplicacion, y es imposible ejecutarla, asi mismo aparece un mensaje que dice "THIS COMPONENT IS BASED ON APPLICATION, WICH IS NOT A VISUAL COMPONENT. SWITCH TO SOURCE MODE TO EDIT IT"
Alguien tiene alguna sugerencia?
He esta buscando informacion al respecto pero solo encuentro las instrucciones de instalacion en Adobe.com
Agradezco su apoyo
Saludos
Jonathan
Por jonathanglez el 16 de Febrero de 2010
Tenia instalado el flex builder 3.0.1 , lo actualice a 3.0.2 y listo
saludos a todos
Por segma el 18 de Febrero de 2010
Y como se integra al projecto?
Saludos!!
Por Arc_Daniel el 12 de Marzo de 2010
Me vi en la necesidad de utilizar esto en Adobe Air y para guardarlo en el escritorio sólo fue necesario modificar las siguientes lineas dentro de la función: 'export' para guardar el ByteArray:
Código :
Como pueden ver sólo comenté las líneas que ya no fueron necesarias.
Saludos.
Por Alcome el 18 de Marzo de 2010
Por hugo ARMANDO el 12 de Abril de 2010
var fr:FileReference = new FileReference(); fr.save(bytes, defaultName);
DISE QUE ES POSIBLE QUE NO ESTE DIFINIDO EL METODO SAVE
LEI UN POKO Y CREO QUE ES POR AL VERISON DE MI FLASH "SEGUUUUN".
ME PODRIAN AYUDAR.
GRACAIS
Por hugo armando el 12 de Abril de 2010
Por jms el 19 de Mayo de 2010
Habéis encontrado alguna solución al tema de los acentos?
Gracias!!
Por Gaston el 26 de Mayo de 2010
Por jms el 02 de Junio de 2010
------
En el archivo "ExcelFile.as" de la libreria de excel, en la linea 256, reemplacen este codigo:
Código :
cell.data.writeByte(0);
cell.data.writeByte(0);
cell.data.writeByte(0);
var len:uint = String(value).length;
cell.data.writeByte(len);
cell.data.writeUTFBytes(value);
por este nuevo:
Código :
var charset:String = "utf-16";
cell.data.writeByte(0);
cell.data.writeByte(0);
cell.data.writeByte(0);
var ba:ByteArray = new ByteArray();
ba.writeMultiByte(String(value),charset);
cell.data.writeByte(ba.length);
cell.data.writeMultiByte(String(value),charset);
------
Gaston:
Project - Properties - Flex Compiler, ahí podrás cambiar la version de flash con la q compilas
Por Claudio el 16 de Junio de 2010
cell.data.writeMultiByte(String(value),charset);
---
¡Hola!
Necesito crear un archivo de Excel con caracteres chinos en su interior.
Con as3xls He intentado cambiar el juego de caracteres de codificación, pero sin éxito.
Vi as3xls guardar el formato de archivo de Excel 2.1. Traté de escribir caracteres chinos directamente en el archivo que acaba de crear, pero sin éxito. Entiendo que Excel 2.1 no administra los caracteres chinos. ¿Cómo puedo guardar un archivo con la versión Excel as3xls bigote superior a 2,1?
Por Diego Trinado el 28 de Junio de 2010
Por emecita el 02 de Julio de 2010
Muchísimas gracias por tu gran trabajo. He usado tu código "ExcelExport.as" para exportar datos de un AdvancedDataGrid y me he encontrado con el problema de que el método no estaba preparado para datos de tipo "Hierarchical".
Adjunto los cambios que he hecho. Ojo, algunos cambios se deben al tipo de XML que he usado.
Aqui van los métodos nuevos:
/**
* Comprueba si el objeto enviado es de tipo HierarchicalCollectionView
*
* @param value Objeto a evaluar
* @return Boolean true o false
* */
static private function isHierarchical(value:Object):Boolean{
if(value is HierarchicalCollectionView){
return true;
}
return false;
}
/**
* Calcula el número total de filas que se van a insertar en el excel
*
* @param value el Objeto de tipo AdvancedDataGrid
* @return int el número total de filas a crear
**/
static private function hierarchicalLength(value:Object):int{
var total:int=0;
var doTimes:int = 0;
var cursor:IViewCursor = value.createCursor();
cursor.seek(CursorBookmark.FIRST);
while ( !cursor.afterLast && doTimes <1 )
{
var xml:XML = new XML(cursor.current as Object);
total += xml.children().length() - 1;
total += childrenLength(xml.children());
doTimes++;
}
return total;
}
/**
* Calcula el número total de filas de nodos hijos que se van a insertar en el excel
*
* @param child lista con los nodos hijos de un nodo dado
* @return int el número total de filas a crear
**/
static private function childrenLength(child:XMLList):int{
var total:int = 0;
if(child.children()!=null){
total = child.children().length();
var childTotal:int = total;
for(var i:int=0; i<childTotal; i++){
if(child[i] != null){
total += childrenLength(child[i].children());
}
}
}
return total;
}
/**
* Rellena la filas con sus datos correspondientes al la estructura XML con atributos
*
* @sheet La hoja de excel
* @rows Número de fila en la que se deben insertar los datos
* @level Nivel de profundidad del nodo en el árbol XML
* @colsValues Array con los nombres de los atributos correspondientes a las columnas
* @children Lista de nodos a inertar en la hoja de excel
* @return Number Devuelve el número de la última fila insertada
**/
static private function fillTable(sheet:Sheet, rows:Number , level:Number, colsValues:Array, children:XMLList):Number{
var curLevel:Number = level;
try{
if(children!=null){
var i:int = 0;
if(level == 0){
i = 1; //Eliminamos primero porque sólo están los nombres de las columnas
}
for (i; i < children.length(); i++) {
for each( var lvXmlAttribute:XML in children[i].attributes()){
var valorAtributo:String = lvXmlAttribute;
var attributo:String = "@"+lvXmlAttribute.name();
var cols:int = colsValues.indexOf(attributo);
if (cols>-1) {
if(cols == 0){ //Pone espacios para indicar el nivel de profundidad
for(var j:int=0; j<level; j++){
valorAtributo = " "+valorAtributo;
}
}
sheet.setCell(rows, cols,valorAtributo);
}
}
rows += 1;
if(children[i] != null){
rows= fillTable(sheet, rows, curLevel++, colsValues, children[i].children());
}
}
}
}catch(e:Error){
e.getStackTrace();
}
return rows;
}
<b>Y aqui va el código que he cambiado del original. Pongo el método completo.</b>
static private function exportToExcel(obj:ICollectionView, colsValues:Array, defaultName:String):void
{
if ( obj == null || colsValues == null || colsValues.length == 0)
return;
var isHierarchical:Boolean = ExcelExporterUtil.isHierarchical(obj); //TODO Bharti
var rows:Number = 0;
var cols:Number = 0;
var cantCols:Number = colsValues.length;
var sheet:Sheet = new Sheet();
if(isHierarchical){ //TODO Nuevo
sheet.resize(hierarchicalLength(obj), colsValues.length);
}else{
sheet.resize(obj.length, colsValues.length);
}
for ( ; cols < cantCols; cols++)
{
sheet.setCell(rows, cols, colsValues[cols].header);
}
cols = 0;
rows++;
var cursor:IViewCursor = obj.createCursor();
while ( !cursor.afterLast )
{
if(!isHierarchical){ //TODO Nuevo
for (cols = 0 ; cols < cantCols; cols++)
{
if ( (cursor.current as Object).hasOwnProperty(colsValues[cols].value) )
sheet.setCell(rows, cols, (cursor.current as Object)[colsValues[cols].value]);
}
rows++;
}else{//TODO Nuevo
var xml:XML = new XML(cursor.current as Object);
var namesArray:Array = new Array();
for (cols = 0 ; cols < cantCols; cols++){
namesArray.push(colsValues[cols].value);
}
fillTable(sheet, rows , 0, namesArray, xml.children());
}
cursor.moveNext();
}
var xls:ExcelFile = new ExcelFile();
xls.sheets.addItem(sheet);
var bytes:ByteArray = xls.saveToByteArray();
var fr:FileReference = new FileReference();
fr.save(bytes, defaultName);
}
Adjunto el xml de ejemplo que estoy usando para rellenar mi AdvancedDataGrid
<form>
<campos uno="Tipos de Trabajo" dos="Partes" tres="Importes Totales" cuatro="Costes Totales"/>
<TIPO_TRABAJOS group="P10" numform="1" totalimporte="0.00" costes="0.00">
<ZONAS group="Z4" numform="1" totalimporte="0.00" costes="0.00"/>
</TIPO_TRABAJOS>
</form>
Espero que esto ayude!
Por rolax el 04 de Agosto de 2010
Por erik el 12 de Agosto de 2010
Por Emiliano el 20 de Agosto de 2010
Gracias
Por Ernesto el 13 de Septiembre de 2010
Código :
cell.data.writeByte(0);
cell.data.writeByte(0);
cell.data.writeByte(0);
var len:uint = String(value).length;
cell.data.writeByte(len);
cell.data.writeUTFBytes(value);
por este nuevo:
Código :
var charset:String = "es-ascii";
cell.data.writeByte(0);
cell.data.writeByte(0);
cell.data.writeByte(0);
var ba:ByteArray = new ByteArray();
ba.writeMultiByte(String(value),charset);
cell.data.writeByte(ba.length);
cell.data.writeMultiByte(String(value),charset);
-------------------
El codigo fuente de puedes bajar de:
http://code.google.com/p/as3xls/source/checkout
-------------------
Cuando exporto me genera el excel con una fila menos, no exporta la ultima fila, alguien sabe cual es el problema
Por Mike el 28 de Septiembre de 2010
1120: Access of undefined property ExcelExporterUtil
que onda ??
gracias
Por Muy útil. el 11 de Octubre de 2010
Para Enesto-blog:
En la función static private function exportToExcel...al decirle a la hoja excel el número de filas que son necesarias, se le indica las filas del dataprovider del datagrid a imprimir, pero hay que contar con una fila mas para las cabeceras
sheet.resize(obj.length +1 , colsValues.length);
Para Mike-blog:
¿Has realizado este import?
import com.kcc.tempos.utils.exporter.ExcelExporterUtil;
En Flex, el ejemplo trabaja bien, salvo por las celdas del datagrid que tengan saltos de linea, ya que estás no se muestran en la celda correspondiente del excel. Esto mismo comenta yoni-blog.
Saludos.
Por i_gonzi el 25 de Octubre de 2010
salu2.
Por Luis el 09 de Noviembre de 2010
¿que se puede hacer para que en el excel salga tal cual se ve en el grid?
Por Dan Master el 18 de Noviembre de 2010
Package cannot nested =(
en la clase
Por Dan Master el 18 de Noviembre de 2010
Por Luis el 23 de Noviembre de 2010
"me encuentro que si tengo campos de fecha en el datagrid en formato dd/mm/aaaa por ejemplo 25/11/2010 en el excel me pone nov-10 y para un campo numerico largo (por ejemplo un número de serie) como 52645897845 me pone 5,2646E+10"
gracias
Por CLAnonimo el 29 de Noviembre de 2010
Oye una pregunta y cual sería la forma para exportar un ArrayCollection a Excel?
Por emecita el 04 de Enero de 2011
http://www.adobe.com/devnet/dreamweaver/application_development.html
Por emecita el 04 de Enero de 2011
http://code.google.com/p/as3xls/wiki/Tutorial
Por javier el 19 de Febrero de 2011
si alguien sabe y me puede explicar se lo agradecería
Por Otaku RzO el 20 de Febrero de 2011
https://github.com/djw/as3xls
Debe ser lo que buscas.
Por vampaynani el 22 de Febrero de 2011
Flash Platform charset codes
Por zahra el 07 de Mayo de 2011
But how i can translate the chart from flex 3 to Excel as chart not as a table (which means like an image)
Por zahra el 07 de Mayo de 2011
Por zahra el 08 de Mayo de 2011
Por zahra el 23 de Mayo de 2011
Por xchacalx el 12 de Julio de 2011
Por xchacalx el 12 de Julio de 2011
Por export a datagrid wi el 05 de Agosto de 2011
i wish to add some enhancement to this project
by permit export function to read hierarchical data
like
mx:DataGridColumn width="40" headerText="'header" dataField="value1.value2.value3.------.valu2n"/>
in function export ,in the block
var cursor:IViewCursor = _dp.createCursor();
while (!cursor.afterLast) {
for (cols = 0; cols < cantCols; cols++) {
var arr:Array = colsValues[cols].value.split(".");
var value:String = getValueOf(arr, cursor.current as Object, arr.length) as String;
sheet.setCell(rows, cols, value);
}
rows++;
cursor.moveNext();
}
make the modif and copy this function too
public static function getValueOf(arr:Array, obj:Object, index:int):Object {
var objBean:Object = obj;
for (var i:int = 0; i < arr.length; i++) {
if (objBean != null) {
objBean = objBean[arr[i]];
}
}
return objBean;
}
enjoy frenids
Por Luiz el 27 de Septiembre de 2011
Revisare el código para ver si encuentro la solución igual si sabes q pueda ser me avisas.
Por Luis G el 12 de Octubre de 2011
Por john el 17 de Noviembre de 2011
Por nicolas el 18 de Noviembre de 2011
Gracias
Por joelui el 29 de Noviembre de 2011
Por Cholito el 01 de Junio de 2012
Por Psilocybio el 18 de Julio de 2012
Ahora la bronca es que...al parecer no exporta la última fila del datagrid...
¿cuál es la solución??
Por cholito el 26 de Julio de 2012
sheet.resize(arrExportResult.length+1,30);
Logré incluir 2 datagrid en la misma hoja excel, porque al parecer esta librería no permite exportar a más de una hoja.
Por zuzii el 30 de Mayo de 2013
Por hk el 31 de Octubre de 2013
Por nesticle8bit el 10 de Noviembre de 2014
Por alberto.03 el 28 de Enero de 2015
Por José el 31 de Enero de 2018
classroom rental space
training rrom rental in singapore
training rooms in singapore
seminar room rental in singapore
indoor team building activities
corporate team building games singapore
team bonding in singapore
team building activities singapore
team building games singapore
10 soft skills you need
administrative office procedures
administrative support courses
adult learning mental skills
adult learning physical skills
anger management courses in singapore
appreciative inquiry courses
archiving and records management
assertiveness and self confidence
attention management courses
basic bookkeeping courses
being a likeable boss
body language basics courses
budgets and financial reports
business acumen courses
business ethics courses
business etiquette courses in singapore
business succession planning courses
business writing courses in singapore
call center training courses
change management courses in singapore
coaching and mentoring courses
coaching sales people courses
collaborative business writing
communication strategies courses
conducting annual employee reviews
conflict resolution courses
contact center training courses
contract management courses in singapore
creating a great webinar
creative problem solving courses
crisis management courses
critical thinking courses in singapore
customer service courses in singapore
customer support courses
cyber security courses in singapore
delivering constructive criticism
developing a lunch and learn
developing corporate behavior
developing creativity courses
developing new managers
digital citizenship courses
emotional intelligence courses
employee motivation courses
employee on boarding courses
employee recognition courses
employee recruitment courses
employee termination processes
entrepreneurship courses in singapore
event planning courses in singapore
executive and personal assistants
facilitation skills courses
generation gaps courses
goal setting and getting things done
handling a difficult customer
health and wellness at work courses
high performance teams inside the company
high performance teams remote work force
hiring strategies courses
human resource management courses in singapore
improving mindfulness
improving self awareness
increasing your happiness
internet marketing fundamentals courses
interpersonal skills courses
job search skills courses
knowledge management courses in singapore
leadership and influence courses
lean process and six sigma
life coaching essentials courses
manager management courses
managing personal finances courses
managing work place anxiety
marketing basics courses
measuring results from training
media and public relations courses
meeting management courses
middle manager courses
millennial on boarding courses
m learning essentials
motivating your sales team
multi level marketing courses
negotiation skills courses
networking outside the company
networking within the company
office politics for managers
organizational skills courses
overcoming sales objections
performance management courses
personal branding courses in singapore
personal productivity courses
presentation skills courses in singapore
project management courses in singapore
proposal writing courses
prospecting and lead generation
public speaking courses in singapore
risk assessment and management courses
safety in the work place courses
sales fundamentals courses
sales training courses in singapore
servant leadership courses
it courses in singapore
microsoft training singapore
corporate training in singapore
corporate sgx
social intelligence courses
social learning courses
social media in the work place
social media marketing courses in singapore
soft skills courses in singapore
stress management courses in singapore
supervising others
supply chain management courses
taking initiative courses
talent management courses
team building for managers
team building through chemistry
teamwork and team building
telephone etiquette courses
telework and telecommuting
time management courses in singapore
trade show staff training
train the trainer courses
virtual team building and management
women in leadership courses
work life balance courses in singapore
work place diversity courses
work place harassment courses
work place violence courses
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
[url=https://books.google.com.sg/books?id=1QykBQAAQBAJ&pg=PT362&lpg=PT362&dq=%22sancy+suraj+singh%22&source=bl&ots=E86QDyrLG2&sig=H-6a_YH-kTWaZWTfPSr1xfm4BOs&hl=en&sa=X&ved=0ahUKEwi3_56hhubVAhWJLo8KHcxTBxQ4ChDoAQgjMAA#v=onepage&q =% 22sancy% 20suraj% 20singh% 22 & f = false]sancy suraj[/url]
sancy suraj
longest colour sequence memorised
sancy suraj
longest colour sequence memorised
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
lunch talks
lunch talks
memory training course
memory training course
cabin crew
online memory course
memory training course
memory training course
memory training course
memory training course
memory training course
speed reading
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
geography tuition for secondary school students in singapore
geography tuition for secondary school students singapore
geography tuition for secondary school students singapore
geography tuition for secondary school students singapore
geography tuition for secondary school students singapore
secondary geography tuition in singapore
history tuition for secondary school students in singapore
social studies tuition for secondary school students in singapore
psle english tuition in singapore
psle science tuition in singapore
secondary 1 chemistry tuition in singapore
secondary 1 physics tuition in singapore
school holiday workshops courses for students in singapore
school holidays activitie in singapore
school holidays activitie in singapore
[url=http://umonictuitionadvantage.com/2017-november-school-holidays-activities-programmes-workshop-courses-camps-for- students-kids-in-singapore/]school holidays activitie in singapore[/url]
school holidays activitie in singapore
study skills
study skills
study skills workshops course in singapore
study skills workshops course in singapore
speed reading
speed reading
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition[
tuition[
tuition[
tuition[
tuition[
tuition[
tuition[
tuition[
student courses
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
team building
team building ideas
team building activities
unique team building
team building
corporate training in singapore
corporate training courses
corporate training courses
corporate training courses
corporate training courses
corporate health talk
corporate health talk
corporate health talk
lunch and learn talk
workplace lunch and learn
corporate training companies in singapore
training companies in singapore
emcee
emcee
health talks
soft skills training course
corporate training providers
professional development courses
training and development courses
short courses in singapore
corporate training courses in singapore
corporate training courses
corporate training in singapore
school holiday workshops courses for students in singapore
business students memory course in singapore
business students memory improvement workshop in singapore
memory improvement course for business students
memory improvement course for business students
business students memory improvement course
business students memory course in singapore
corporate health talks singapore
corporate health talks in singapore
corporate health talk singapore
corporate health talk in singapore
corporate health talks singapore
corporate health talks singapore
finance students memory training course in singapore
finance students memory training course in singapore
finance students memory training course in singapore
memory training courses for finance students in singapore
memory training courses for finance students in singapore
memory improvement courses for finance students in singapore
pinnacle minds
memory course
study skills
speed reading
memory training
school holiday
lunch and learn
march school holidays workshops
march school holidays workshops
march school holidays workshops
march school holidays workshops
march school holidays workshops
june school holidays workshops
june school holidays workshops
june school holidays workshops
june school holidays workshops
september 2018 school holidays workshops
september 2018 school holidays workshops
september 2018 school holidays workshops
september 2018 school holidays workshops
november 2018 school holidays workshops
november 2018 school holidays workshops
november 2018 school holidays workshops
november 2018 school holidays workshops
december 2018 school holidays workshops
december 2018 school holidays workshops
december 2018 school holidays workshops
december 2018 school holidays workshops
top 10 soft skills you need training course
administrative office procedures training course
administrative support training course
anger management training course
appreciative inquiry training course
archiving and records management training course
archiving and records management training course
self confidence and assertiveness training course
improving your attention management training course
bacis bookkeeping training course
being a likeable boss training course
body language training course
budgets and-financial reports training course
business acumen training course
business ethics training course
business etiquette training course
business succession planning training course
business writing training course
call centre training course
change management training course
civility in the workplace training course
coaching and mentoring training course
coaching salespeople training course
collaborative business writing training course
communication strategies training course
conducting annual employee reviews training course
conflict resolution training course
contact centre training course
contract management training course
creating a great webinar training course
creative problem solving training course
crisis management training course
critical thinking training course
customer service training course
customer support training course
cyber security training course
delivering constructive criticism training course
developing lunch and learn training course
developing corporate behavior training course
developing creativity training course
developing new managers training course
digital citizenship training course
emotional intelligence training course
employee motivation training course
employee onboarding training course
employee recognition training course
employee recruitment training course
employee termination processes training course
entrepreneurship training course
event planning training course
executive and personal assistants training course
facilitation skills training course
generation gaps training course
goal setting and getting things done training course
handling a difficult customer training course
health and wellness at work training course
high performance teams inside the company training course
high performance teams remote workforce training course
hiring strategies training course
human resource management training course
improving mindfulness training course
improving self awareness training course
internet marketing fundamentals training course
interpersonal skills training course
job search skills training course
knowledge management training course
leadership and influence training course
lean process and six sigma training course
life coaching essentials training course
manager management training course
managing personal finances training course
managing workplace anxiety training course
marketing basics training course
measuring results from training course
media and public relations training course
meeting management training course
middle manager training course
millennial onboarding training course
mlearning essentials training course
motivating your sales team training course
negotiation skills training course
networking outside the company training course
networking within the company training course
office politics for managers training course
organizational skills training course
overcoming sales objections training course
performance management training course
personal branding training course
personal productivity training course
presentation skills training course
project management training course
proposal writing training course
prospecting and lead generation training course
public speaking training course
risk assessment and management training course
safety in the workplace training course
sales fundamentals training course
servant leadership training course
social intelligence training course
social learning training course
social media in the workplace training course
social media marketing training course
stress management training course
supervising others training course
supply chain management training course
taking initiative training course
talent management training course
team building for managers training course
team building through chemistry training course
teamwork and team building training course
telephone etiquette training course
telework and telecommuting training course
time management training course
top 10 sales secrets training course
trade show staff training course
train the trainer training course
virtual team building and management training course
women in leadership training course
work life balance training course
workplace diversity training course
workplace harassment training course
workplace violence training course
half day memory improvement courses workshops
speed reading courses workshops in singapore
10 soft skills you need corporate training course in singapore
administrative office procedures corporate training course in singapore
administrative support corporate training course in singapore
anger management corporate training course in singapore
appreciative inquiry corporate training course in singapore
archiving and records management corporate training course in singapore
self confidence assertiveness corporate training course in singapore
improving your attention management corporate training course in singapore
basic bookkeeping corporate training course in singapore
being a likeable boss corporate training course in singapore
body language basics corporate training course in singapore
budgets and financial reports corporate training course in singapore
business acumen corporate training course in singapore
business ethics corporate training course in singapore
business etiquette corporate training course in singapore
business succession planning corporate training course in singapore
business writing corporate training course in singapore
call center corporate training course in singapore
change management corporate training course in singapore
civility in the workplace corporate training course in singapore
coaching and mentoring corporate training course in singapore
coaching salespeople corporate training course in singapore
collaborative business writing corporate training course in singapore
communication strategies corporate training course in singapore
conducting annual employee reviews corporate training course in singapore
conflict resolution corporate training course in singapore
contact center corporate training course in singapore
contract management corporate training course in singapore
creating a great webinar corporate training course in singapore
creative problem solving corporate training course in singapore
crisis-management corporate training course in singapore
critical thinking corporate training course in singapore
customer service corporate training course in singapore
customer support corporate training course in singapore
cyber security corporate training course in singapore
delivering constructive criticism corporate training course in singapore
developing a lunch and learn corporate training course in singapore
developing corporate behavior corporate training course in singapore
developing creativity corporate training course in singapore
developing new managers corporate training course in singapore
digital citizenship corporate training course in singapore
emotional intelligence corporate training course in singapore
employee motivation corporate training course in singapore
employee onboarding corporate training course in singapore
employee recognition corporate training course in singapore
employee recruitment corporate training course in singapore
employee termination processes corporate training course in singapore
entrepreneurship training course in singapore
event planning corporate training course in singapore
executive and personal assistants corporate training course in singapore
facilitation skills corporate training course in singapore
generation gaps corporate training course in singapore
goal setting and getting things done corporate training course in singapore
handling a difficult customer corporate training course in singapore
health and wellness at work corporate training course in singapore
high performance teams inside the company corporate training course in singapore
high performance teams remote workforce corporate training course in singapore
hiring strategies corporate training course in singapore
human resource management corporate training course in singapore
improving mindfulness corporate training course in singapore
improving self awareness corporate training course in singapore
increasing your happiness corporate training course in singapore
internet marketing fundamentals corporate training course in singapore
interpersonal skills corporate training course in singapore
job search skills corporate training course in singapore
knowledge management corporate training course in singapore
leadership and influence corporate training course in singapore
lean process and six sigma corporate training course in singapore
life coaching essentials corporate training course in singapore
manager management corporate training course in singapore
managing personal finances corporate training course in singapore
marketing basics corporate training course in singapore
measuring results from corporate training course in singapore
media and public relations corporate training course in singapore
meeting management corporate training course in singapore
middle manager corporate training course in singapore
millennial onboarding corporate training course in singapore
mlearning essentials corporate training course in singapore
motivating your sales team corporate training course in singapore
negotiation skills corporate training course in singapore
networking outside the company corporate training course in singapore
networking within the company corporate training course in singapore
office politics for managers corporate training course in singapore
organizational skills corporate training course in singapore
overcoming sales objections corporate training course in singapore
performance management corporate training course in singapore
personal branding corporate training course in singapore
personal productivity corporate training course in singapore
presentation skills corporate training course in singapore
project management corporate training course in singapore
proposal writing corporate training course in singapore
prospecting and lead generation corporate training course in singapore
public speaking corporate training course in singapore
[url