Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

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

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 26-01-2008
gsilvei gsilvei is offline
Miembro
 
Registrado: jul 2006
Posts: 44
Poder: 0
gsilvei Va por buen camino
recorrer dbgrid

Hola, estoy necesitando una luz para mi duda, tengo un ClientDataSet que su contenido es visualizado en un DBGrid, donde por ejemplo aparecen 200 registros, y tengo una pequeña rutina que recorre todo el DBGrid, mi duda es como podria pausar mi rutina por ejemplo hasta el registro 50, y despues continuar por otros 50 y asi sucesivamente.



Código Delphi [-]

procedure TForm1.EnviarCorreoMultiple(DBGrid :TDBGrid; email, Asunto :String);
var
 Direcciones :String;
begin
 Direcciones := '';
 with DBGrid1.DataSource.DataSet do
 begin
   First; //Vamos al primer registro...
   while not Eof do //Recorramos el DataSet hasta el ultimo registro...
   begin
     Direcciones := Direcciones + FieldByName(email).AsString + ';'; //Agrega Direcciones...
   Next;
   end;
 end;

 SetLength(Direcciones, Length(Direcciones) -1); //Quitemos el punto y coma que sobra...
 ShellExecute(Handle, 'open', pchar('mailto:'+Direcciones+'?subject='+Asunto),  '', '',SW_SHOW);
end;



mi SpeedButton1:

Código Delphi [-]

procedure TForm1.SpeedButton1Click(Sender: TObject);
begin
   EnviarCorreoMultiple(DBGrid1, 'email', 'Consultas...');
end;



gracias por la ayuda,

saludos
Responder Con Cita
  #2  
Antiguo 26-01-2008
Avatar de eduarcol
[eduarcol] eduarcol is offline
Miembro Premium
 
Registrado: ago 2003
Ubicación: En los estados Zulia y Merida de Venezuela
Posts: 4.151
Poder: 25
eduarcol Va por buen camino
Código Delphi [-]
procedure TForm1.EnviarCorreoMultiple(DBGrid :TDBGrid; email, Asunto :String);
var
 Direcciones :String;
 nCont: Integer; //Agregamos una variable para contar los registros 
begin
 Direcciones := '';
 with DBGrid1.DataSource.DataSet do
 begin
   First; //Vamos al primer registro...
   while not Eof do //Recorramos el DataSet hasta el ultimo registro...
   begin
     Direcciones := Direcciones + FieldByName(email).AsString + ';'; //Agrega Direcciones...
     Inc(nCont); //Contamos cuantas direcciones van
     //si hay mas de 50 enviamos e inicializamos
     if nCont >= 50 then
     begin
         SetLength(Direcciones, Length(Direcciones) -1); //Quitemos el punto y coma que sobra...
         ShellExecute(Handle, 'open', pchar('mailto:'+Direcciones+'?subject='+Asunto),  '', '',SW_SHOW);
         nCont := 0;
         Direcciones := '';  
     end;
   Next;
   end;
   //si al salir del ciclo quedaron direcciones se envian
   if nCont >= 1 then
     begin
         SetLength(Direcciones, Length(Direcciones) -1); //Quitemos el punto y coma que sobra...
         ShellExecute(Handle, 'open', pchar('mailto:'+Direcciones+'?subject='+Asunto),  '', '',SW_SHOW);
         nCont := 0;
         Direcciones := '';  
     end;
 end;


end;
__________________
...Yo naci en esta ribera del arauca vibr@d0r
Soy hermano de la espuma,
de la garza, de la rosa y del sol...
Viva Venezuela
Responder Con Cita
  #3  
Antiguo 26-01-2008
gsilvei gsilvei is offline
Miembro
 
Registrado: jul 2006
Posts: 44
Poder: 0
gsilvei Va por buen camino
Hola eduarcol,
gracias por la luz,
funciona realmente como necesitaba,
saludos
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
Recorrer un STRING creus Varios 3 07-01-2007 22:52:37
¿Como recorrer la culumna de un dbgrid y hallar el valor mas alto? ANXO OOP 3 12-04-2006 20:20:51
Recorrer un dbgrid el_barto Conexión con bases de datos 15 03-08-2005 22:36:07
Ocultar movimiento cursor en dbGRid al recorrer TQuery. setry2 Conexión con bases de datos 2 23-03-2005 15:19:02
Recorrer un dbgrid con navigator Javier_A OOP 1 13-01-2004 17:38:47


La franja horaria es GMT +2. Ahora son las 05:04: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