Cómo seleccionar elemento ComboBox por índice

Iniciado por novalida, 10 Diciembre 2010, 22:47 PM

0 Miembros y 2 Visitantes están viendo este tema.

novalida

Hola!!!
Me gustaría saber si alguien me puede ayudar pues tengo una duda al intentar mejorar un pequeño programa con el que estoy aprendiendo.
Tengo un control ComboBox en el que he añadido elementos y sus índices a partir de una base de datos, por lo que cada elemento queda identificado por cada índice.
El caso es que me gustaría poder seleccionar el elemento a partir de un índice que se introdujera en un TextBox.
En el caso de los meses, por ejemplo, introducir 1 en el TextBox, pulsar un botón, y sería seleccionado en el ComboBox el elemento "Enero".

Por otro lado me gustaría saber si alguien me puede indicar algun ebook de Visual Basic 6.0 que sea bueno y completo, ya que no encuentro demasiada información al respecto.

Un saludo y espero respuesta :)

ignorantev1.1

Código (vb) [Seleccionar]
Private Sub Command1_Click()
    Combo1.ListIndex = Val(Text1.Text)
End Sub



No se si te referias a esto  :rolleyes:

frekency

Creo que con esto ya te lo coge

Private Sub Command1_Click()
    Combo1.ListIndex = Text1.Text
End Sub

Sino le haces un cast a integer y listo


Combo1.ListIndex = Cint (text1.text)



ignorantev1.1

Código (vb) [Seleccionar]


Text1.Text="hola"
...
Private Sub Command1_Click()
    Combo1.ListIndex = Val(Text1.Text)  '<---si text1.text no es numerico se convierte en 0
End Sub



Private Sub Command2_Click()
    Combo1.ListIndex = Text1.Text '<---- Error no coinciden los tipos
End Sub

Edu

Te falta leer mas entonces primero, porq necesitarias usar el Select q cuando leas sabras a q me refiero, busca en google:

elguille.info por si no es asi y busca tutorial de vb6 de el q son buenos y largos.. xD

novalida

Muy buenas!!!
Muchas gracias por responder tan rápido.
Bueno, lo que me habeis indicado ya lo había intentado y no me funciona.
Así cargué con los datos el ComboBox:


With oComboBox
       .AddItem ("Enero")
       .ItemData(oComboBox.NewIndex) = 1
       .AddItem ("Febrero")
       .ItemData(oComboBox.NewIndex) = 2
       .AddItem ("Marzo")
       .ItemData(oComboBox.NewIndex) = 3
       .AddItem ("Abril")
       .ItemData(oComboBox.NewIndex) = 4
       .AddItem ("Mayo")
       .ItemData(oComboBox.NewIndex) = 5
       .AddItem ("Junio")
       .ItemData(oComboBox.NewIndex) = 6
       .AddItem ("Julio")
       .ItemData(oComboBox.NewIndex) = 7
       .AddItem ("Agosto")
       .ItemData(oComboBox.NewIndex) = 8
       .AddItem ("Septiembre")
       .ItemData(oComboBox.NewIndex) = 9
       .AddItem ("Octubre")
       .ItemData(oComboBox.NewIndex) = 10
       .AddItem ("Noviembre")
       .ItemData(oComboBox.NewIndex) = 11
       .AddItem ("Diciembre")
       .ItemData(oComboBox.NewIndex) = 12
End With




Al hacer lo que me proponéis siempre sale un elemento por debajo. Es decir, el índice del combobox es 0, pero yo le indiqué para el elemento "Enero" el índice 1. Al indicarle en el textbox el índice 1 me cambia el combobox a "Febrero" y no "Enero".
:S

XXX-ZERO-XXX , gracias por responder, pero no veo el uso del Select para lo que yo quiero, el cual es que el valor asociado a cada elemento de un combobox estará ligado al id asociado a ese elemento dentro una base de datos. EL ejemplo de los meses es algo sencillo para poder exponer mejor la duda que tengo.

Edu

Ah pense q era algo mas facil , te entendi mal, y por lo q sabes supuestamente no necesitaras el manual q te dije q leas je, y yo sigo sin entender q quieres hacer xD

novalida

XXX-ZERO-XXX , no te preocupes, quizás no me explico muy bien.
A ver si lo puedo hacer mejor :)
He creado un ComboBox de esta manera, y a cada elemento le asigno un índice: Enero 1, Febrero 2, etc...



With oComboBox
       .AddItem ("Enero")
       .ItemData(oComboBox.NewIndex) = 1
       .AddItem ("Febrero")
       .ItemData(oComboBox.NewIndex) = 2
       .AddItem ("Marzo")
       .ItemData(oComboBox.NewIndex) = 3
       .AddItem ("Abril")
       .ItemData(oComboBox.NewIndex) = 4
       .AddItem ("Mayo")
       .ItemData(oComboBox.NewIndex) = 5
       .AddItem ("Junio")
       .ItemData(oComboBox.NewIndex) = 6
       .AddItem ("Julio")
       .ItemData(oComboBox.NewIndex) = 7
       .AddItem ("Agosto")
       .ItemData(oComboBox.NewIndex) = 8
       .AddItem ("Septiembre")
       .ItemData(oComboBox.NewIndex) = 9
       .AddItem ("Octubre")
       .ItemData(oComboBox.NewIndex) = 10
       .AddItem ("Noviembre")
       .ItemData(oComboBox.NewIndex) = 11
       .AddItem ("Diciembre")
       .ItemData(oComboBox.NewIndex) = 12
End With




La respuesta que me han dado:



Private Sub Command1_Click()
  Combo1.ListIndex = Val(Text1.Text)
End Sub



Según esta respuesta, si en el TextBox pongo 1, el evento Command1_Click() selecciona el elemento "Febrero" y no "Enero" como yo quería que ocurriese.

raul338

novalida, el ItemData es un espacio extra en el que puedes meter algun dato. no es el index necesariamente

Creo recordar en el metodo Add tienes para poner un index especifico, lo tendrias que hacer asi

Código (vb) [Seleccionar]
With oComboBox
        Call .AddItem ("Enero", 1)
        Call .AddItem ("Febrero", 2)
        Call .AddItem ("Marzo", 3)
End With


:) espero que te sirva, si no entiendes me dices, estoy algo apurado y contesto rapido :xD

novalida

#9
raul338, gracias por contestar. He entendido que a un elemento se le puede asociar un valor Integer a través del ItemData. Quizás hibiese sido más correcto denominar el asunto de la duda como Cómo seleccionar elemento ComboBox por su ItemData :)
Ya había intentado la solución que me propones, pero no sé por qué al poner .AddItem ("Enero", 1) me da el error: Se esperaba: =

Se me acaba de ocurrir esta solución:



Private Sub Command1_Click()
    Dim i As Integer
   
   For i = 0 To Me.Combo1.ListCount - 1 Step 1
       Me.Combo1.ListIndex = i
       If Me.Combo1.ItemData(Me.Combo1.ListIndex) = Val(Me.Text1.Text) Then
           Exit Sub
       End If
   Next
End Sub



No sé si es la única solución, pero si hay una que sea más elegante me gustaría conocerla.
Con VB6 no tengo mucha experiencia y quizás no se me ocurre algo que sea más sencillo.