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 09-10-2012
lucas05 lucas05 is offline
Miembro
 
Registrado: ago 2010
Posts: 116
Poder: 14
lucas05 Va por buen camino
Capturar datos de un combobox

Hola, podrían ayudarme con el siguiente problema, tengo una tabla que contiene dos columnas: id y nombre.
Lo que hago es mostrar el contenido de la columna nombre en un ComboBox, utilizando el siguiente codigo:
Código Delphi [-]
 for i:=1 to ZQuery1.RecordCount do
    begin
      ComboBox1.AddItem(ZQuery1.fieldbyname('nombre').AsString,ComboBox1);
      ZQuery1.Next;
   end;

Lo que intento hacer es que al seleccionar un dato del ComboBox, se guarde en una variable el dato seleccionado y en otra variable el id que corresponde a ese dato.

Espero haber sido claro, desde ya muchas gracias.
Responder Con Cita
  #2  
Antiguo 09-10-2012
cancun cancun is offline
Miembro
 
Registrado: may 2003
Ubicación: Cancun, México
Posts: 114
Poder: 21
cancun Va por buen camino
Hola


Deberias usar TDBLookUpComboBox asignas la propiedad ListSource el DataSource del ZQuery el Campo Nombre a ListField y ID a KeyField, en el evento OnClick pones


Código:
procedure TForm1.DBLookupComboBox1Click(Sender: TObject);
begin
  A:=DBLookupComboBox1.KeyValue;     // ID seleccionado
  B:=DBLookupComboBox1.Text;          // Nombre seleccionado
end;

Saludos
__________________
Cancun, Q.Roo, México
Responder Con Cita
  #3  
Antiguo 09-10-2012
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.275
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Otra opción es utilizar el puntero del segundo parámetro para almacenar un entero. De esa forma aprovechas ese valor. Piensa que al final el puntero no es más que un número.

Puede añadir los valores al combobox de esta forma:

Código Delphi [-]
  // en tu caso en segundo valor serían los valores del ID
  ComboBox1.AddItem('Lunes', Pointer(1234));
  ComboBox1.AddItem('Martes', Pointer(34));
  ComboBox1.AddItem('Miercoles', Pointer(9999));

Para recuperar los valores del ID, del elemento seleccionado puedes hacer lo siguiente:

Código Delphi [-]
  // Hay algo seleccionado
  if (ComboBox1.ItemIndex <> -1) then begin
    // puntero al objeto del elemento seleccionado
    p := Pointer(ComboBox1.Items.Objects[ComboBox1.ItemIndex]);
    // Obtenemos el entero almacenado
    i := Integer(p);
    // lo pintamos en un label
    Label1.Caption := IntToStr(i);
  end;

Un saludo.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #4  
Antiguo 09-10-2012
lucas05 lucas05 is offline
Miembro
 
Registrado: ago 2010
Posts: 116
Poder: 14
lucas05 Va por buen camino
Gracias a los dos por su ayuda.

Neftali con respecto a tu solución, funciona bien, pero solo cuando el combobox contiene datos estáticos, en mi caso los datos del combobox son dinámicos ya que vienen de una base de datos.
Como podría adaptarlo para que funcione cuando los datos son dinámicos?

Nuevamente gracias.
Responder Con Cita
  #5  
Antiguo 09-10-2012
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.275
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por lucas05 Ver Mensaje
Neftali con respecto a tu solución, funciona bien, pero solo cuando el combobox contiene datos estáticos, en mi caso los datos del combobox son dinámicos ya que vienen de una base de datos.
Como podría adaptarlo para que funcione cuando los datos son dinámicos?
No entiendo lo que quieres decir con datos estáticos y datos dinámicos.
Lo que yo te he puesto es un ejemplo, se trata de que utilices el código que has puesto anteriormente para rellenar el combobox:

Código Delphi [-]
 for i:=1 to ZQuery1.RecordCount do
    begin
      ComboBox1.AddItem(ZQuery1.fieldbyname('nombre').AsString,ComboBox1);
      ZQuery1.Next;
   end;

Y tal como añades el nombre, añadas también el ID en el segundo parámetro, tal y como has añadido el primero (pero con un código similar al del ejemplo).

A la hora de recuperar el ID, pues tal y como te he puesto también en el ejemplo, pero con tu ID.
Al final NOMBRE y "Lunes" son cadenas y ID y 1234 son integers. No veo la diferencia...
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #6  
Antiguo 09-10-2012
lucas05 lucas05 is offline
Miembro
 
Registrado: ago 2010
Posts: 116
Poder: 14
lucas05 Va por buen camino
Gracias por la ayuda.
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
Capturar datos de un memo ZayDun Varios 3 13-02-2008 17:39:16
capturar datos sin duplicarlos cristiano Tablas planas 2 14-11-2007 07:38:41
capturar texto no seleccionado, ComboBox sakuragi OOP 3 10-08-2005 23:28:22
capturar datos didier Varios 1 27-05-2004 01:34:21
Capturar datos R.Rodriguez Varios 4 21-05-2004 21:25:57


La franja horaria es GMT +2. Ahora son las 23:52:48.


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