Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
Aunque hay muchos generadores de informes para Delphi como pueden ser QuickReport, Rave Reports, Report Manager,
etc., no hay procesador de textos ms completo que Microsoft Word.
Es este artculo vamos a ver como generar un nuevo documento de Word y poder introducir textos, tablas, figuras, notas al
pie, etc. Esto lo vamos a conseguir utilizando el componente TWordApplication que encuentra en el apartado Servers
dentro de la paleta de componentes.
Aunque no he conseguido averiguar la inmensidad de funciones que incorpora este objeto s que podemos generar un
informe ms o menos decente.
EL COMPONENTE TWORDAPPLICATION
Creamos un par de variables del tipo OleVariant para poder enviar parmetros a funciones:
var
Documento, Texto: OleVariant;
Conectamos con Microsoft Word y le decimos que cree un nuevo documento que va a llamarse Informe.doc y que va a
guardarse en el mismo directorio donde nos encontramos:
// Conectamos con Word y creamos un nuevo documento
Documento := ExtractFilePath( Application.ExeName ) + 'Informe.doc';
Word.Connect;
Word.Documents.Add(EmptyParam,EmptyParam,EmptyParam,EmptyParam);
Tambin vamos a insertar una nota al pie de pgina y otra al final del documento:
// Insertamos una nota al pie y una nota al final
Texto := 'Nota al pie de pgina';
FootNotes.Add( Range, EmptyParam, Texto );
Texto := 'Nota al final';
EndNotes.Add( Range, EmptyParam, Texto );
Aparte de aadir el contenido a cada celda hemos establecido para toda la primera fila el fondo de color verde y la fuente
de color amarillo:
Rows.Item(1).Shading.BackgroundPatternColor := clGreen; // fonfo verde
Rows.Item(1).Range.Font.Color := clYellow; // fuente amarilla
Por ltimo he aadido una lnea recta cuyas coordenadas van por pixels:
Word.ActiveDocument.Shapes.AddLine( 200, 200, 250, 250, EmptyParam );
Aunque me hubiera gustado poder aadir muchos ms elementos a este informe, debido a la psima documentacin de
Delphi 2007 y que en la web tampoco abundan muchos ejemplos (lo nico decente que he visto es de unas pginas rusas y
japonesas). Si averiguo ms cosas lo ampliar en un futuro.
Pruebas realizadas en RAD Studio 2007.
Publicado por Administrador en 09:42 7 comentarios
Etiquetas: ofimtica
05 diciembre 2008
Creando una hoja de clculo desde Delphi
Al igual que en el artculo anterior vimos como leer datos de una hoja de clculo de Microsoft Excel hoy vamos a ver
como crearla, rellenarla con datos y frmulas para luego guardarla en disco.
Para ello utilizaremos el mismo componente: TExcelApplication. Le pondremos igualmente en su propiedad Name el
nombre Excel. Mi objetivo es crear esta hoja de clculo:
Esta hoja contiene 4 columnas con las unidades, el nombre del artculo, el precio y total lnea. La columna del total debe
contener una frmula que multiplique las unidades por el precio.
1 Declaramos la variable Hoja de tipo _WorkSheet para que apunte a la hoja de clculo con la que estamos trabajando:
var
Hoja: _WorkSheet;
Aparte de introducir los ttulos he utilizado las propiedades ColumnWidth y Font.Bold para ensanchar la columna del
artculo y para poner todos los ttulos en negrita.
Al ser la propiedad Value2 de tipo Variant podemos introducir datos de todo tipo sin necesidad de realizar conversiones.
6 En la ltima columna vamos a introducir una frmula para multiplicar unidades por precio:
// Frmulas
Hoja.Range['D2','D2'].Formula := '=A2*C2';
Hoja.Range['D3','D3'].Formula := '=A3*C3';
Hoja.Range['D4','D4'].Formula := '=A4*C4';
7 Damos formato decimal a las columnas del precio y los totales y para sta ltima columna le cambiamos los colores:
// Formato decimal
Hoja.Range['C2','D4'].NumberFormat := '0,00';
// Damos formato a los totales
Hoja.Range['D2','D4'].Font.Bold := True; // fuente negrita
Hoja.Range['D2','D4'].Font.Color := clBlue; // fuente azul
Hoja.Range['D2','D4'].Borders.Color := clRed; // borde rojo
Hoja.Range['D2','D4'].Interior.Color := clYellow; // fondo amarrillo
La hoja de clculo la hemos guardado con el nombre Nueva.xls dentro de mismo directorio donde se ejecuta nuestra
aplicacin.
Y es que no hay nada mejor que sacarle partido a Microsoft Office para que nos haga el trabajo sucio.
Pruebas realizadas en RAD Studio 2007.
Publicado por Administrador en 16:49 18 comentarios
Etiquetas: ofimtica
28 noviembre 2008
Leyendo datos de hojas de clculo de Microsoft Excel
Si hay algo que nos piden frecuentemente a los programadores de gestin es poder recoger o enviar datos a los programas
ofimticos ms populares: Microsoft Word, Microsoft Excel y Microsoft Access.
Lo ms comn suele ser leer datos de una hoja de clculo y guardarlos en nuestra base de datos, aunque tambin tenemos
la posibilidad de enviarle la informacin para que Excel nos haga una grfica espectacular.
Una hoja de clculo es realmente un libro que puede contener una o ms hojas de clculo:
EL COMPONENTE TEXCELAPPLICATION
Hay que reconocer que la cantidad de parmetros que tiene el mtodo Open es impresionante:
Aunque no hay que asustarse porque lo que necesitamos realmente es el primer parmetro (el nombre del archivo excel a
abrir). Los dems son para elegir si queremos abrirlo en modo slo lectura, introducir una contrasea, etc.
Una vez que hemos abierto la hora de clculo tenemos que situarnos en la Hoja1. Para ello creamos las siguientes
variables:
var
i: Integer;
si: String;
Hoja: _WorkSheet;
Las variables i y si son para recorrer las celdas de la hoja de clculo y la variable Hoja va a apuntar a una hoja en
concreto. En nuestro caso la primera:
Hoja := Excel.Worksheets.Item[1] as _WorkSheet;
Para leer informacin de las celdas de la hoja de clculo tenemos que conocer las coordenadas horizontales (A,B,C,) y
las verticales (1,2,3,). Cuando lea la informacin la voy a volcar a un componente ListView configurado con estas
columnas:
Ahora slo queda ir recorriendo cada fila hasta que encontremos una fila vaca:
i := 2;
si := IntToStr( i );
repeat
with ListView.Items.Add do
begin
SubItems.Add( Hoja.Range['A'+si,'A'+si].Value2 ); // Cdigo
SubItems.Add( Hoja.Range['B'+si,'B'+si].Value2 ); // Nombre
SubItems.Add( Hoja.Range['C'+si,'C'+si].Value2 ); // CIF
SubItems.Add( Hoja.Range['D'+si,'D'+si].Value2 ); // Saldo
end;
Inc( i );
si := IntToStr( i );
until ( VarType( Excel.Range['A'+si,'A'+si].Value2 ) = VarEmpty );
La propiedad Value2 de cada celda devuelve un tipo Variant, por ello utilizo la funcin VarType para comprobar si lo
que hay en la celda esta vaco (VarEmpty). De ese modo sabemos cuando hemos terminado de leer datos.
Igualmente podemos escribir datos en cualquier celda de la hoja de clculo con total naturalidad:
Hoja.Range['B2','B2'].Value2 := TRANSPORTES GARCIA, S.L.;
De esta manera podemos crear nuestras plantillas de hojas de clculo con grficas incluidas y desde Delphi le enviamos la
informacin.
Pruebas realizadas en RAD Studio 2007.