Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   OOP (https://www.clubdelphi.com/foros/forumdisplay.php?f=5)
-   -   Leer celdas desde el Word (https://www.clubdelphi.com/foros/showthread.php?t=28290)

Javier_A 15-12-2005 11:35:09

Leer celdas desde el Word
 
Hola a tod@s,
despues de buscar en los foros, está claro como exportar datos de delphi al word, pero no tengo clara la forma de detectar cuantas celdas hay en un documento word y exportarlas, por ejemplo, a un dataset.
Os espero....
Salu2

Javier_A 21-12-2005 08:17:42

Hola de nuevo,
Al no haber respuestas tengo dudas acerca de si es posible, ¿ se puede leer desde Delphi un documento word y tener acceso a sus celdas ?

Salu2

Citlalli 30-12-2005 22:35:42

Javier_A, para empezar creo que te estas confundiendo y en lugar de hablar de Word estas hablando de excel, de ser asi, te pongo la forma para poder exportar datos de una hoja de excel a un dataset:

1. Agrega las componentes ADO a la paleta de componentes
2. Agrega una componente TAdoConnection a tu formulario y pon su propiedad LoginPrompt en false.
3. Haz doble click en la componente para que se abra el editor de la propiedad ConnectionString y selecciona "Use connection string" y luego oprime el botón "Build" para que se abra la ventana de vínculo de datos.
4. En esa ventana, en la ficha "Proveedor" (Provider) selecciona Microsoft Jet 4.0 OLE DB y da click en siguiente.
5. En la ficha "Conexión" (Connection), en el cuadro "Usar nombre de origen de datos" (o algo así) escribe el nombre del archivo excel (te deja buscarlo con un botoncito)
6. En la ficha "Todas" (All) selecciona "Extended properties" y luego "Modificar valor" y escribes "Excel 8.0" (sin las comillas)
7. Oprime 'Ok' las veces necesarias para cerrar todas las ventanas.
Esta fue la parte "difícil", crear la cadena de conexión.
8. Ahora coloca una componente TAdoDataSet en el formulario y asigna el AdoConnectio a su propiedad "Connection"
9. Pon la propiedad CommandType del DataSet en cmdTableDirect y en la propiedad CommandText escoges la hoja que desees del archivo de Excel (si todo salió bien te aparece una lista con las hojas del libro) El nombre de la hoja aparece seguido de un signo $, es normal.
A partir de aquí ya todo es "coser y cantar". El AdoDataSet funciona similar a un Table (aunque de sólo lectura) y lo abres con su propiedad Active:=true o con el método Open (cuidado porque a mi me marcó un error cuando lo activé en tiempo de diseño y luego corrí la aplicación así que mejor lo dejé inactivo y lo abrí hasta la ejecución).
Para la transferencia simplemente usas un bucle:

code:--------------------------------------------------------------------------------
while not AdoDataSet1.EoF do
begin
Table1.Append;
Table1.Fields[0].Value := AdoDataSet1.Fields[0].Value;
Table1.Fields[1].Value := AdoDataSet1.Fields[1].Value;
Table1.Fields[2].Value := AdoDataSet1.Fields[2].Value;
...
AdoDataSet1.Next;
end;
--------------------------------------------------------------------------------


saludos


La franja horaria es GMT +2. Ahora son las 14:55:29.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi