Buscar y contar palabras en un listbox

Iniciado por rapbyone, 8 Agosto 2017, 21:49 PM

0 Miembros y 1 Visitante están viendo este tema.

rapbyone

Hola amigos, una vez mas solicito su ayuda, tengo un listbox de la siguiente manera:

manzana [1]
naranja [1]
plátano [2]
sandia [2]
melón [1]
durazno [2]
guinda [1]

y necesito obtener el valor de cuantos [1] y cuantos [2] hay en la lista.
¿Se puede hacer de alguna manera?
Gracias amigos  ;-)

Eleкtro

#1
Cita de: rapbyone en  8 Agosto 2017, 21:49 PMy necesito obtener el valor de cuantos [1] y cuantos [2] hay en la lista.

¿Cómo dices, la cantidad de "[1]" y [2]" en total?. y ¿VB6, o VB.NET?.

Simplemente puedes iterar los elementos y hacer un substring para quedarte con el número/cantidad, y entonces utilizar cualquier tipo de contenedor para ir almacenando y sumando las coincidencias de cada número/cantidad. Te muestro un ejemplo escrito en VB.NET donde utilizo la colección de tipo Dictionary:

Código (vbnet) [Seleccionar]
Dim amountsDict As New Dictionary(Of Integer, Integer)(EqualityComparer(Of Integer).Default)

For Each item As String In Me.ListBox1.Items
   Dim amount As Integer = CInt(item.Substring(item.LastIndexOf(" "c) + 1).Trim({"["c, "]"c}))

   If Not amountsDict.ContainsKey(amount) Then
       amountsDict.Add(amount, 1)
   Else
       amountsDict(amount) += 1
   End If
Next item

For Each pair As KeyValuePair(Of Integer, Integer) In amountsDict
   Console.WriteLine("Count of ""[{0}]"": {1} ", pair.Key, pair.Value)
Next pair


Resultado de ejecución:
CitarCount of "[1]": 4
Count of "[2]": 3

...De todas formas, ¿por que estás utilizando un ListBox para empezar?. La funcionalidad de un ListBox es representar un único elemento, sin embargo tú estás intentando representar dos cosas distintas al mismo tiempo: elemento y cantidad/número, por lo tanto deberías utilizar otro control más apropiado para representar la información de forma adyacente pero individual, como por ejemplo ListView o DataGridView.

Saludos.








rapbyone

#2
Cita de: Eleкtro en  8 Agosto 2017, 23:25 PM
¿Cómo dices, la cantidad de "[1]" y [2]" en total?. y ¿VB6, o VB.NET?.

Amigo es para VB6,  :-(

Serapis

#3
No existe ninguna otra manera que recorrer la lsita mediante un bucle.

Recorre la lista con un bucle,
- Si el elemento acaba en "[1]" añade 1 al contador de ese tipo...
- Si el elemento acaba en "[2]" añade 1 al contador de este otro elemento...
- Si no acaba en ninguno de estos (suponiendo que tengas también algún "[0]", no haces nada, o quizás debas también sumarlo si por ejemplo acaban en "[2]"...
Fin del bucle


...que en VB6 sería más o menos:
Código (vb) [Seleccionar]
Dim k as integer

For k = 0 to Listbox1.Listcount-1
   If (Instrrev(Listbox1.List(k) = "[1]" then
       Cuenta1 = (Cuenta1 + 1)
   Elseif Instrrev(Listbox1.List(k) = "[2]" then
       Cuenta2 = (Cuenta2 + 1)
   End if
Next

Msgbox "Cuenta de [1]: " & cstr(Cuenta1) & vbcrlf & _
      "Cuenta de [2]: " & cstr(cuenta2)


Ahora, coincido con Elektro, cuandio te reclama:
CitarLa funcionalidad de un ListBox es representar un único elemento (por cada ítem), sin embargo tú estás intentando representar dos cosas distintas al mismo tiempo: elemento y cantidad/número, por lo tanto deberías utilizar otro control más apropiado

rapbyone

Cita de: NEBIRE en 10 Agosto 2017, 16:25 PM
No existe ninguna otra manera que recorrer la lsita mediante un bucle.

Recorre la lista con un bucle,
- Si el elemento acaba en "[1]" añade 1 al contador de ese tipo...
- Si el elemento acaba en "[2]" añade 1 al contador de este otro elemento...
- Si no acaba en ninguno de estos (suponiendo que tengas también algún "[0]", no haces nada, o quizás debas también sumarlo si por ejemplo acaban en "[2]"...
Fin del bucle


...que en VB6 sería más o menos:
Código (vb) [Seleccionar]
Dim k as integer

For k = 0 to Listbox1.Listcount-1
   If (Instrrev(Listbox1.List(k) = "[1]" then
       Cuenta1 = (Cuenta1 + 1)
   Elseif Instrrev(Listbox1.List(k) = "[2]" then
       Cuenta2 = (Cuenta2 + 1)
   End if
Next

Msgbox "Cuenta de [1]: " & cstr(Cuenta1) & vbcrlf & _
      "Cuenta de [2]: " & cstr(cuenta2)


Ahora, coincido con Elektro, cuandio te reclama:

Amigos, en primer lugar les agradezco por darse el tiempo de ayudarme, he aprendido de vb6 pero aún hay cosas que no entiendo del todo, si bien no es el mejor control, dadas las características de mi programa, necesito que sea de esa manera.

Intenté con el código, pero me marca un error, al parecer falta un separador de listas, intenté agregando un ")" pero me dice que "El argumento no es opcional" sobre "InStrRev".



Gracias nuevamente amigos

Serapis

#5
claro... perdón, lo escribí rápido...

La instrucción InStrRev, exige al menos 2 parámetros obligatorios... la cadena donde se busca, y la cadena que se quiere buscar y devuelve la posición donde se localiza. 0 si no se encontró.

Lo corrijo, aunque esperaba que cualquier error de sintaxis, fueras tu mismo capaz de arreglarlo... corrijo también la falta de los parétesis de cierre...

Código (vb) [Seleccionar]
   Dim k as integer
   
   For k = 0 to Listbox1.Listcount-1
       If (Instrrev(Listbox1.List(k), "[1]")>0) then  ' (Instrrev(Listbox1.List(k) = "[1]"
           Cuenta1 = (Cuenta1 + 1)
       Elseif Instrrev(Listbox1.List(k),"[2]")>0) then
           Cuenta2 = (Cuenta2 + 1)
       End if
   Next
   
   Msgbox "Cuenta de [1]: " & cstr(Cuenta1) & vbcrlf & _
          "Cuenta de [2]: " & cstr(cuenta2)


- Aunque estés empezando, cuando se te presenten dudas con alguna instrucción, o alguna palabra clave, llevas el puntero sobre la palabra (o la seleccionas) y usas la tecla F1, aparecerá la ayuda (si la tienes instalada), sobre dicha instrucción o palabra clave, para profundizar sobre el tema, con los detalles precisos.
- También si te canta un error puedes ir a a la ayuda para profundizar en el tema si el mensaje te resulta tan breve que no te aclara demasiado...

okik

A ver si te sirve esto:

Código (vb) [Seleccionar]

'Recorre los elementos de la lista en busca de valores 1 Y 2
For n = 0 To List1.ListCount - 1
Dim valor As Integer
   valor = Mid(List1.List(n), Len(List1.List(n)) - 1, 1)
   Select Case valor
       Case 1: Unos = Unos + 1
       Case 2: Doses = Doses + 1
   End Select
Next n
MsgBox ("Unos: " & Unos)
MsgBox ("Doses: " & Doses)


List1.ListCount
Obtiene la longitud de la lista. Para generar un bucle que recorra el list uso "List1.ListCount - 1" porque el primer elemento de la lista tiene índice 0

List1.List(Indice)
Devuelve un elemento de la lista. Por ejemplo "manzana [1]"

valor = Mid(List1.List(n), Len(List1.List(n)) - 1, 1)
Mid es una función que obtiene un carácter o caracteres dependiendo de el lugar y longitud especificados  según los parámetros de dicha función:

Mid(String, Start As Long, [Length])

por ejemplo:

Mid("camión", 3, 2)

Devolvería "mi"

La primera posición antes de c es 1.


Len(List1.List(n))
Len devuelve la longitud de la cadena en caracteres.


De modo que :
   valor = Mid(List1.List(n), Len(List1.List(n)) - 1, 1)

Devuelve el número. que hay entre corchetes [..]