Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Servers
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 28-04-2015
marcial marcial is offline
Miembro
 
Registrado: may 2003
Posts: 147
Poder: 22
marcial Va por buen camino
Gracias Neftalí, estudio lo que dices y te cuento.
Responder Con Cita
  #2  
Antiguo 29-04-2015
marcial marcial is offline
Miembro
 
Registrado: may 2003
Posts: 147
Poder: 22
marcial Va por buen camino
Vaya Neftali, no he podido. Si no te he entendido mal en el primer caso (un documento word con 100 hojas) mi origen de datos debe tener 100 registros. Para ello hago lo siguiente:
Código Delphi [-]
                MailMerge.Clear;
                MailMerge.DocumentName := NombreDocumento;
                MailMerge.Columns := 'Nombre;Direccion;';

            Socios.First;
            While not Socios.Eof do
            begin

              MailMerge.Append;
              MailMerge['Nombre'] := Socios.FieldByName('Nombre').AsString;
              MailMerge['Direccion'] := Socios.FieldByName('Direccion').AsString;

              Socios.Next;
            end;

            MailMerge.Merge;

El resultado es correcto, me presenta en pantalla un documento word con las 100 páginas y cuando lo cierro me pide si lo quiero guardar o no. Todo Correcto.

Lo que quiero conseguir ahora con el botón "Enviar Correos" es que se graben (Word.SaveAs) 100 documentos personalizados de 1 hoja cada uno y cuando trato de hacer que mi fuente de datos tenga 1 sólo registro viene el problema. He seguido tu consejo y he creado un fichero de texto (FS) con los nombres de los clientes que he seleccionado y luego hago lo siguiente:

Código Delphi [-]
                While Not Eof (FS) do
                begin
                Readln (FS, NombreSocio);

                    SQL := 'Select * from Socios where Nombre = ''' + NombreSocio + '''';
                    CONSULTA;

                Word := CreateOleObject('Word.Application');
                Word.Documents.Add(FormBuscaFicheros.FoundFiles.ItemFocused.Caption);
                Documento := Word.Documents.Item(1);

                MailMerge.Clear;
                MailMerge.DocumentName := NombreDocumento;
                MailMerge.Columns := 'Nombre;Direccion;';
                MailMerge.Append;
                MailMerge['Nombre'] := Socios.FieldByName('Nombre').AsString;
                MailMerge['Direccion'] := Socios.FieldByName('Direccion').AsString;

                MailMerge.Merge;
//              Word.Visible := False;

                Word.ActiveDocument.SaveAs(ExtractFilePath(Application.ExeName)+'Documentos\'+'Carta al Socio ' + Socios.FieldByName('Nombre').AsString + '.doc');
                Word.Quit(EmptyParam, EmptyParam, EmptyParam);

                end;

Como verás hago una CONSULTA para que mi fichero de socios (que es el asignado en la Combinacion de Correspondencia) tenga 1 solo registro, pero el resultado es que empiezan a abrirse pantallas word unas con el Documento, otras con datos no legibles, luego a cada documento me pregunta que si quiero guardar los datos....en fin, que no es lo deseado. Yo lo que quiero conseguir es que el proceso sea transparente para el usuario y que cuando termine, tenga en la carpeta correspondiente 100 cartas individuales. Yo creo un documento word, luego hago el MailMerge y luego lo salvo con el nombre que yo quiero todo por cada uno de los registros que tiene el Fichero de Texto (FS).

Podrías ayudarme con esto??.

Muchas gracias a ti y a todos los que lo habeis intentado.
Responder Con Cita
  #3  
Antiguo 30-04-2015
marcial marcial is offline
Miembro
 
Registrado: may 2003
Posts: 147
Poder: 22
marcial Va por buen camino
Sin embargo, si en vez de usar MailMerge, uso DOCVARIABLE, para el botón "IMPRIMIR DOCUMENTOS" el resultado es el contrario. Cuando quiero que mi fuente de datos tenga 100 registros, me genera un documento word con la primera página escrita (correcta) y 99 páginas en blanco. Uso este código:

Código Delphi [-]
                Word := CreateOleObject('Word.Application');
                Word.Documents.Add(FormBuscaFicheros.FoundFiles.ItemFocused.Caption);
                Documento := Word.Documents.Item(1);

            Socios.First;

            While not Socios.Eof do
            begin

                  I := IndexOfName(Documento.Variables, 'Nombre');
                  if I = 0 then Documento.Variables.Add('Nombre', ImpresionWord.FieldByName('Nombre').AsString)
                           else Documento.Variables.Item(I).Value := ImpresionWord.FieldByName('Nombre').AsString;

                  I := IndexOfName(Documento.Variables, 'Direccion');
                  if I = 0 then Documento.Variables.Add('Direccion', ImpresionWord.FieldByName('Direccion').AsString)
                           else Documento.Variables.Item(I).Value := ImpresionWord.FieldByName('Direccion').AsString;


                Documento.Fields.Update;

                Salto := wdSectionBreakNextPage;
                Word.ActiveDocument.Content.Paragraphs.Last.Range.InsertBreak(salto);

              Socios.Next;
            end;

              Word.Visible := true;

           Fecha := Copy(DateToStr(Date),1,2) + Copy(DateToStr(Date),4,2) + Copy(DateToStr(Date),7,4);
           Hora := Copy(TimeToStr(Time),1,2) + Copy(TimeToStr(Time),4,2) + Copy(TimeToStr(Time),7,4);

           Word.ActiveDocument.SaveAs(ExtractFilePath(Application.ExeName)+'Documentos\'+'Envio Documentacion Fecha ' + Fecha + ' Hora '+ Hora + '.doc');
           Word.Quit(EmptyParam, EmptyParam, EmptyParam);

Para el botón "MANDAR CORREOS" utilizo el siguiente código que SI lo hace correctamente:

Código Delphi [-]
            Socios.First;
            While not Socios.Eof do
            begin

                Word := CreateOleObject('Word.Application');
                Word.Documents.Add(FormBuscaFicheros.FoundFiles.ItemFocused.Caption);
                Documento := Word.Documents.Item(1);
                Documento.Variables.Add('Nombre', ImpresionWord.FieldByName('Nombre').AsString);
                Documento.Variables.Add('Direccion', ImpresionWord.FieldByName('Direccion').AsString);
                Documento.Fields.Update;

            Word.ActiveDocument.SaveAs(ExtractFilePath(Application.ExeName)+'Documentos\'+'Carta al Socio ' + ImpresionWord.FieldByName('Nombre').AsString + '.doc');
                Word.Quit(EmptyParam, EmptyParam, EmptyParam);

              Socios.Next;
            end;
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Word en Delphi cmm07 Varios 6 02-01-2009 13:08:19
Delphi con Word Olga Varios 0 21-12-2005 15:03:44
De Delphi a Word Medardo Impresión 5 04-02-2005 20:20:22
Word con Delphi Jordy Servers 4 22-01-2004 15:55:07
uso de Word en delphi zuriel_zrf Servers 0 04-11-2003 09:13:51


La franja horaria es GMT +2. Ahora son las 15:10:11.


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
Copyright 1996-2007 Club Delphi