[RESUELTO] ¿Es posible exportar desde IBDataSet a Excel (sin tener instalado Excel)?
#1
Posted 05 November 2009 - 04:57 PM
¿Es posible exportar desde IBDataSet a Excel (sin tener instalado Excel)?.
Uso Delphi 7, IBExpress y Firebird 2.0
Me planteo exportar datos desde un IBDataset a una hoja de cálculo.
Supongo que el formato Excel es el más difundido. Por ello, creo que es el más adecuado.
Sin embargo, no tengo instalado Excel (uso OpenOffice.org) y he leido en un foro que tener instalado Excel es imprescindible. ¿Es así?.
¿Hay alguna forma de exportar con el formato Excel sin tener Excel instalado?.
En caso de que sea posible... cualquier ejemplo de código (indicando lo que hay que añadir en el Uses, si puede ser; sería muy bienvenido).
De antemano muchas gracias.
Ramón.
#2
Posted 05 November 2009 - 05:20 PM
hay un componente muy bueno realizado por Neftali miembro del foro ClubDelphi que hace esto que necesitas, desafortunadamente en este momento no está en funcionamiento la página donde puedes obtener estos componentes.
Te dejo el enlace a su página y espero que en breve esté de nuevo disponible.
http://neftali.clubd....com/?tag=excel
Salud OS
#3
Posted 05 November 2009 - 05:24 PM
#4
Posted 05 November 2009 - 05:26 PM
http://www.maxcompon...age=1&linkid=17
Esta página ya cerró sus puertas pero creo que aún se puede descargar el componente.
Saludos
#5
Posted 06 November 2009 - 01:05 PM
Me han dado pistas muy concretas
Así que voy a empezar probando con TmxNativeExcel de MaxComponents. Ya antes lo hice (sin éxito) con el ejemplo que me indica Enecumene y no he podido acceder a la página de Neftali.
Muchas gracias a todos.
Ramón.
#6
Posted 06 November 2009 - 05:32 PM
He instalado el componente TmxNativeExcel y he ejecutado el demo incluido, logrando lo que buscaba al iniciar este hilo.
Muchas gracias a todos.
Ramón.
#7
Posted 06 November 2009 - 05:51 PM
Salud OS
#8
Posted 18 June 2010 - 11:18 AM
http://cc.embarcadero.com/Item/13462
Pero hay que estar registrado en Embarcadero para poder descargar...
Bueno, incluyo ese código con un poco de código de ejemplo:
Este es el código del Unit:
unit Hoja_Calculo; interface uses Classes ; procedure XlsBeginStream(XlsStream: TStream; const BuildNumber: Word); procedure XlsEndStream(XlsStream: TStream); procedure XlsWriteCellLabel(XlsStream: TStream; const ACol, ARow: Word; const AValue: string); procedure XlsWriteCellNumber(XlsStream: TStream; const ACol, ARow: Word; const AValue: Double); procedure XlsWriteCellRk(XlsStream: TStream; const ACol, ARow: Word; const AValue: Integer); var CXlsBof : array[0..5] of Word = ($809, 8, 00, $10, 0, 0); CXlsEof : array[0..1] of Word = ($0A, 00); CXlsLabel : array[0..5] of Word = ($204, 0, 0, 0, 0, 0); CXlsNumber: array[0..4] of Word = ($203, 14, 0, 0, 0); CXlsRk : array[0..4] of Word = ($27E, 10, 0, 0, 0); implementation procedure XlsBeginStream(XlsStream: TStream; const BuildNumber: Word); begin // CXlsBof[4] := BuildNumber; XlsStream.WriteBuffer(CXlsBof, SizeOf(CXlsBof)); end; procedure XlsEndStream(XlsStream: TStream); begin XlsStream.WriteBuffer(CXlsEof, SizeOf(CXlsEof)); end; procedure XlsWriteCellRk(XlsStream: TStream; const ACol, ARow: Word; const AValue: Integer); var V: Integer; begin CXlsRk[2] := ARow; CXlsRk[3] := ACol; XlsStream.WriteBuffer(CXlsRk, SizeOf(CXlsRk)); V := (AValue shl 2) or 2; XlsStream.WriteBuffer(V, 4); end; procedure XlsWriteCellNumber(XlsStream: TStream; const ACol, ARow: Word; const AValue: Double); begin CXlsNumber[2] := ARow; CXlsNumber[3] := ACol; XlsStream.WriteBuffer(CXlsNumber, SizeOf(CXlsNumber)); XlsStream.WriteBuffer(AValue, 8); end; procedure XlsWriteCellLabel(XlsStream: TStream; const ACol, ARow: Word; const AValue: string); var L: Word; begin L := Length(AValue); CXlsLabel[1] := 8 + L; CXlsLabel[2] := ARow; CXlsLabel[3] := ACol; CXlsLabel[5] := L; XlsStream.WriteBuffer(CXlsLabel, SizeOf(CXlsLabel)); XlsStream.WriteBuffer(Pointer(AValue)^, L); end; end.
Desde un form que tiene un RadioGroup1 (con 3 opciones: decimal, entero y texto) y un Button1.
Este es el evento OnClick de Button1:
procedure TForm1.Button1Click(Sender: TObject); var aa : string ; FStream: TFileStream; I, J: Integer; begin aa := ExtractFilePath( Application.ExeName ) + 'HojaCalculo_01.xls' ; FStream := TFileStream.Create( aa, fmCreate); try XlsBeginStream(FStream, 0); for I := 1 to strtoint ( Edit2.Text ) do // Columnas for J := 1 to strtoint ( Edit1.Text ) do // Filas begin case RadioGroup1.ItemIndex of 0: XlsWriteCellNumber(FStream, I, J, 34.34); 1: XlsWriteCellRk(FStream, I, J, 3434); 2: XlsWriteCellLabel(FStream, I, J, Format('Cell: %d,%d', [I, J])); end; end; XlsEndStream(FStream); finally FStream.Free; end; // Si se quiere leer con una hoja de cálculo (por ej. OpenOffice.Org ShellExecute(Handle,nil, PChar( aa ), '', '',SW_SHOWNORMAL) ; end;
El Unit se guarda con el nombre que corresponda y se une al proyecto.
Desde el Form1 (que debe tener el Unit en el Uses), se hace click en el button1 y nada mas.
Bueno, espero que a alguien le sea tan útil como me lo ha resultado a mí.
Saludos.
Ramón.
#9
Posted 18 June 2010 - 11:26 AM
Saludos.
#10
Posted 18 November 2021 - 02:08 PM
En este enlace hay un Unit que permite realizar facilmente una exportación de datos a formato excel sin tener excel instalado:
http://cc.embarcadero.com/Item/13462
Pero hay que estar registrado en Embarcadero para poder descargar...
Bueno, incluyo ese código con un poco de código de ejemplo:
Este es el código del Unit:
delphi
unit Hoja_Calculo; interface uses Classes ; procedure XlsBeginStream(XlsStream: TStream; const BuildNumber: Word); procedure XlsEndStream(XlsStream: TStream); procedure XlsWriteCellLabel(XlsStream: TStream; const ACol, ARow: Word; const AValue: string); procedure XlsWriteCellNumber(XlsStream: TStream; const ACol, ARow: Word; const AValue: Double); procedure XlsWriteCellRk(XlsStream: TStream; const ACol, ARow: Word; const AValue: Integer); var CXlsBof : array[0..5] of Word = ($809, 8, 00, $10, 0, 0); CXlsEof : array[0..1] of Word = ($0A, 00); CXlsLabel : array[0..5] of Word = ($204, 0, 0, 0, 0, 0); CXlsNumber: array[0..4] of Word = ($203, 14, 0, 0, 0); CXlsRk : array[0..4] of Word = ($27E, 10, 0, 0, 0); implementation procedure XlsBeginStream(XlsStream: TStream; const BuildNumber: Word); begin // CXlsBof[4] := BuildNumber; XlsStream.WriteBuffer(CXlsBof, SizeOf(CXlsBof)); end; procedure XlsEndStream(XlsStream: TStream); begin XlsStream.WriteBuffer(CXlsEof, SizeOf(CXlsEof)); end; procedure XlsWriteCellRk(XlsStream: TStream; const ACol, ARow: Word; const AValue: Integer); var V: Integer; begin CXlsRk[2] := ARow; CXlsRk[3] := ACol; XlsStream.WriteBuffer(CXlsRk, SizeOf(CXlsRk)); V := (AValue shl 2) or 2; XlsStream.WriteBuffer(V, 4); end; procedure XlsWriteCellNumber(XlsStream: TStream; const ACol, ARow: Word; const AValue: Double); begin CXlsNumber[2] := ARow; CXlsNumber[3] := ACol; XlsStream.WriteBuffer(CXlsNumber, SizeOf(CXlsNumber)); XlsStream.WriteBuffer(AValue, 8); end; procedure XlsWriteCellLabel(XlsStream: TStream; const ACol, ARow: Word; const AValue: string); var L: Word; begin L := Length(AValue); CXlsLabel[1] := 8 + L; CXlsLabel[2] := ARow; CXlsLabel[3] := ACol; CXlsLabel[5] := L; XlsStream.WriteBuffer(CXlsLabel, SizeOf(CXlsLabel)); XlsStream.WriteBuffer(Pointer(AValue)^, L); end; end.
Desde un form que tiene un RadioGroup1 (con 3 opciones: decimal, entero y texto) y un Button1.
Este es el evento OnClick de Button1:
delphi
procedure TForm1.Button1Click(Sender: TObject); var aa : string ; FStream: TFileStream; I, J: Integer; begin aa := ExtractFilePath( Application.ExeName ) + 'HojaCalculo_01.xls' ; FStream := TFileStream.Create( aa, fmCreate); try XlsBeginStream(FStream, 0); for I := 1 to strtoint ( Edit2.Text ) do // Columnas for J := 1 to strtoint ( Edit1.Text ) do // Filas begin case RadioGroup1.ItemIndex of 0: XlsWriteCellNumber(FStream, I, J, 34.34); 1: XlsWriteCellRk(FStream, I, J, 3434); 2: XlsWriteCellLabel(FStream, I, J, Format('Cell: %d,%d', [I, J])); end; end; XlsEndStream(FStream); finally FStream.Free; end; // Si se quiere leer con una hoja de cálculo (por ej. OpenOffice.Org ShellExecute(Handle,nil, PChar( aa ), '', '',SW_SHOWNORMAL) ; end;
El Unit se guarda con el nombre que corresponda y se une al proyecto.
Desde el Form1 (que debe tener el Unit en el Uses), se hace click en el button1 y nada mas.
Bueno, espero que a alguien le sea tan útil como me lo ha resultado a mí.
Saludos.
Ramón.
Hola
Esta http://cc.embarcadero.com/Item/13462, no esta disponible, alguien sabe donde puedo descargar esa unit para implementarla en un codigo?
#11
Posted 19 November 2021 - 08:29 AM
Hola
Esta http://cc.embarcadero.com/Item/13462, no esta disponible, alguien sabe donde puedo descargar esa unit para implementarla en un codigo?
Hola
Si está disponible.
Saludos