Office Automation/es
│
Deutsch (de) │
English (en) │
español (es) │
français (fr) │
italiano (it) │
русский (ru) │
中文(中国大陆) (zh_CN) │
La capacidad de interactuar con los programas ofimáticos y así generar hojas de cálculo, documentos de texto y presentaciones desde nuestro código puede ser muy valiosa en la oficina, y ahorrar mucho tiempo a aquellos que lo necesiten. Un ejemplo es la creación de aplicaciones que pueden leer archivos en un formato arbitrario y guardar la salida en un archivo de Excel, una tarea mucho más eficiente de hacer con el código a continuación expuesto que de forma manual.
Utilizando UNO Bridge de OpenOffice
OpenOffice tiene enlaces para lenguaje como C, Java, JavaScript y Python. En Windows, OpenOffice también puede ser manipulado en Pascal a través de automatización COM (véase más adelante), pero actualmente no existe una forma sencilla de usar OpenOffice UNO (Universal Network Objects -Objetos Universales de Red-) desde Pascal en OS X y Linux. Si estás interesado en el desarrollo de un puente entre OO y Pascal, por favor mira estos enlaces para más información (precaución: estos enlaces son muy técnicos al estilo SUN):
Ver también el tema más abajo sobre Python.
Usar automatización COM para interactuar con OpenOffice y Microsoft Office
La automatización COM es exclusiva de Windows, así que los ejemplos que siguen no funcionan ni en OS X ni en Linux. Para estas plataformas ver Prescindiendo de la automatización COM de Windows. Si sólo necesita crear y/o ver un documento de texto desde su programa, da un vistazo al XDev Toolkit.
Este es una ejemplo sencillo de cómo abrir un documento con tu programa utilizando el servidor de automatización de OpenOffice. Recuerda que esto sólo funciona en Windows.
program PruebaOpenOffice;
{$IFDEF FPC}
{$MODE Delphi}
{$ELSE}
{$APPTYPE CONSOLE}
{$ENDIF}
uses
SysUtils, Variants, ComObj;
const
NombreServidor = 'com.sun.star.ServiceManager';
var
Servidor : Variant;
Escritorio : Variant;
ParametrosCarga : Variant;
Documento : Variant;
CursorTexto : Variant;
begin
if Assigned(InitProc) then
TProcedure(InitProc);
try
Servidor := CreateOleObject(NombreServidor);
except
WriteLn('No puedo arrancar OpenOffice.');
Exit;
end;
Escritorio := Servidor.CreateInstance('com.sun.star.frame.Desktop');
ParametrosCarga := VarArrayCreate([0, -1], varVariant);
{Crear un documento nuevo}
Documento := Escritorio.LoadComponentFromURL('private:factory/swriter',
'_blank', 0, ParametrosCarga);
CursorTexto := Documento.Text.CreateTextCursor;
{Insertarun documento existente} //Substituye por tu ruta y documento
CursorTexto.InsertDocumentFromURL('file:///C|/mi/ruta/midocumento.doc',
ParametrosCarga);
end.
Y aquí un ejemplo sencillo de cómo abrir un documento con tu programa usando el servidor de automatización de Word. Ten en cuenta que este ejemplo sólo funciona en Windows y sólo cuando se compila con Delphi; Free Pascal 2.2.2 compila el código, pero no funciona. Por favor. Comprueba más adelante o prueba con una versión más reciente de FPC.
program PruebaMsOffice;
{$IFDEF FPC}
{$MODE Delphi}
{$ELSE}
{$APPTYPE CONSOLE}
{$ENDIF}
uses
SysUtils, Variants, ComObj;
const
NombreServidor = 'Word.Application';
var
Servidor : Variant;
begin
if Assigned(InitProc) then
TProcedure(InitProc);
try
Servidor := CreateOleObject(NombreServidor);
except
WriteLn('No puedo arrancar M$Word.');
Exit;
end;
{Abrir un documento existente} //Substituye por tu ruta y documento
Servidor.Documents.Open('c:\mi\ruta\midocumento.doc');
Servidor.Visible := True; {Hacer Word visible}
end.
Utilizar Python para manejar OpenOffice
Dado que OpenOffice incluye soporte para Python, sería posible ejecutar secuencias de comandos de Python desde Pascal para manipular OO, en lugar de un enlace real para lenguaje Pascal. Éstos son los pasos para un posible enfoque para realizarlo:
- Probar que UNO vía macro de Python funciona dentro de OO
- Probar que UNO vía macro de Python independiente
- Crear el soporte para correr macros de Python en Pascal
- Probar que UNO vía macro de Python funciona con Pascal
- Crear una clase Pascal para envolver Python UNO
Nota: Las siguientes macros han sido probadas con OpenOffice 2.3.1 en Windows XP y NeoOffice 2.2.5 Patch 6 en Mac OS X 10.4.11 (PowerPC).
Paso 1. Probar que UNO vía macro de Python funciona dentro de OO
OpenOffice tiene herramientas para crear macros de JavaScript, pero no las macros Python, por lo que utilizaremos el editor de texto para guardar la secuencia de comandos siguiente para el archivo prueba_macro.py y colocarlo en la carpeta de macros OO del usuario. En Windows, esta carpeta es:
C:\Document and Setting\<NombreUsuario>\Application Data\OpenOffice.org2\user\Scripts\python\Library1
En Mac OS X, la carpeta es:
~/Library/Preferences/NeoOffice-2.2/usuario/Scripts/python/Library1
En ambas plataformas es necesario crear la carpeta python/Library1.
Este es el código para prueba_macro.py, adaptado del ejemplo OO Pascal anterior:
# Macro Python que prueba UNO creando un nuevo documento e inserta en el algo de texto.
import uno
def PruebaNuevoDoc():
ctx = uno.getComponentContext()
smgr = ctx.ServiceManager
escritorio = smgr.createInstance('com.sun.star.frame.Desktop')
doc = escritorio.loadComponentFromURL('private:factory/swriter', '_blank', 0, ())
textoCursor = doc.Text.createTextCursor()
doc.Text.insertString(textoCursor, 'Hola Mundo', 0)
En OO, seleccionar Herramientas | Macros | Organizar Macros | Python... y ejecuta la macro para comprobar que funciona.
Paso 2. Probar que UNO funciona con una macro de Python independiente
Aquí el código para una macro independiente:
# Macro Python que prueba UNO creando un nuevo documento e inserta en el algo de texto.
import sys
if sys.platform == 'darwin':
sys.path.append('/Applications/NeoOffice.app/Contents/MacOS')
import officehelper
ctx = officehelper.bootstrap()
smgr = ctx.ServiceManager
escritorio = smgr.createInstance('com.sun.star.frame.Desktop')
doc = escritorio.loadComponentFromURL('private:factory/swriter', '_blank', 0, ())
textoCursor = doc.Text.createTextCursor()
doc.Text.insertString(textoCursor, 'Hola Mundo', 0)
Guarda el archivo prueba.py y ejecútalo desde la línea de órdenes de Windows. Nota: En Windows y Linux, usa la versión de Python incluida con OO; en Mac OS X, usa la versión Python 2.3. del sistema.
"\program files\openoffice.org 2.3\program\python" test.py
En Mac OS X, corre la macro en una ventana de Terminal así:
#!/bin/sh export DYLD_LIBRARY_PATH=$DYLD_LIBRARY_PATH":/Applications/NeoOffice.app/Contents/MacOS" python2.3 test.py
Desafortunadamente, esta macro no funciona bien en Windows o Mac OS X. En Windows, se muestra un diálogo de error sin texto (¡!) Y luego escribe un mensaje de error en la consola que dice "No se puede conectar a un servidor soffice". En Mac OS X, se inicia NeoOffice y crea el nuevo documento, a continuación, NeoOffice se cierra abruptamente.
UNO Python Cosas por Hacer (ToDo)
Obviamente se necesita investigación adicional antes de proceder al paso 3. Te invitamos a trabajar en ello. Éstas son un par de cosas para probar:
- Pruebas en Linux
- Pruebas en versiones más recientes de OpenOffice
- Enero. 5, 2009: Resultados de probar OpenOffice 3 en Windows:
- OO 3.0.0 soporte para macros Python de usuario roto (paso 1); arreglado en OO 3.0.1 RC1.
- Paso 2 el diálogo vacío ya no se muestra y el el mensaje de error de la consola es diferente, pero OO sigue sin arrancar.
- Ten en cuenta que las rutas a diferentes partes de OO y de las macros de usuario han cambiado con OO 3.
Usar la librería Spreadsheet de Free Pascal
Otra manera de automatizar tareas repetitivas con hojas de cálculo es utilizar la librería FPSpreadsheet. Puede leer y escribir hojas de cálculo en varios formatos y no requiere tener ninguna aplicación externa instalada en la máquina.
Escribir un archivo Excel usando ADO
- Si alguien puede documentar este paso la información vendría muy bien.
Leer y escribir archivos Excel utilizando el componente Excel Interface
El componente está disponible aquí:
Dado que la Automatización no está disponible, pero COM si lo está, el componente de interfaz de Excel proporciona un conjunto de clases que encapsula las llamadas a Lazarus a la interfaz COM de Excel (por debajo de la Automatización). Así se oculta la mayoría del aburrido código de trabajo a bajo nivel.
Funcionalidad:
- crear y cargar libros de trabajo de excel,
- guardar libros de trabajo,
- crear y acceder a hojas,
- extraer y dar valores (y formulas) en las celdas,
- recuperar y vambiar colores de las celdas,
- recuperar y cambiar la anchura de las columnas y la altura de la filas,
- crear comentarios,
- crear formas,
- crear gráficos.
Obtener una hoja es sencillo:
// Iniciando un libro de trabajo excel corriente:
ExcelAplicacion := TExcelApplication.Create(nil);
ExcelAplicacion.Active := True;
ExcelAplicacion.Visible := True;
LibrosExcel := ExcelAplicacion.WorkBooks;
unLibroExcel := LibrosExcel.Open(NombreArchivodePrueba)
HojasExcel := unLibroExcel.Sheets;
unaHojaExcel := HojasExcel.Sheet('Hoja1');
Trabajar con las celdas es muy fácil:
// añadiendo un valor
unaCelda := unaHojaExcel.Cells(1, 1);
unaCelda.Value := 10;
// añadiendo una formula
unaCelda := unaHojaExcel.Cells(2,1);
unaCelda.Formula := '=A1+10';
// obteniendo el valor claculado por Excel
unValor := unaCelda.Value;
En el ejemplo facilitado hay muchos más ejemplos.
Enlaces externos
- Descripción del formato de fichero Excel en el sitio web de OpenOffice