![]() |
Problema con listbox
Tengo un listbox al que le cargo datos tipo integer, lo que necesito es hacer un boton que me los ordene a esos datos de menor a mayor y otro boton que me cuente el total de datos que tiene la lista.....
Espero dejarme entender.. Desde ya muchas gracias:) |
pues tienes la propiedad sorted que te ayuda a ordenar y la propiedad items que dentro de este viene el count para saber la cantidad...
|
Me parece que no va a ser tan fácil como usar Sorted porque el ordenamiento se hace como texto y no como números. Eso implica, por ejemplo, que '10' va antes que '2' a pesar de que 2 es menor que 10.
Se me ocurre usar un TStringList auxiliar y su método CustomSort:
// Saludos |
Cita:
|
....Y como hago para seleccionar el primer dato de la lista o el ultimo para guardarlo en una variable?
|
Un Saludo. |
Un Saludo. |
No comprendo la línea "SL.CustomSort(CompareNumbers);"
Debido a que la función CompareNumbers está declarada como: "function CompareNumbers(List: TStringList; Index1, Index2: Integer): Integer;" y debería recibir los parámentros declarados, o sea, ¿no hace falta especificar esos parámetros? por ejemplo: "SL.CustomSort(CompareNumbers(List, Index1, Index2));" Expliquemen por favor. Gracias. |
Para entender esto, pimero hay que ver la declaración del método CustomSort:
El parámetro es de tipo TStringListSortCompare, que está declarado así:
Es decir, el parámetro que se pasa a CustomSort es una función. Esto hay que leerlo bien antes de digerirlo. No se le pasa el valor que devuelve la función (que sería un entero), se le pasa toda la función como parámetro. Si bien esto puede sonar raro, quizá se te aclare si meditas en para qué se necesita tal cosa. El origen del problema en este hilo, es que el orden natural de los elementos de un ListBox es textual, no numérico; son dos tipos distintos de ordenamiento: 1, 2, 3, 4, 5, 6 , 7, 8, 9, 10 (numérico) 1, 10, 2, 3, 4, 5, 6, 7, 8, 9 (textual) En un orden numérico, 2 es menor que 10, pero en un orden textual, 10 es menor que 2 (puesto que al comparar el primer caracter, 1 es menor que 2). Lo que se ve entonces, es que una lista de elementos siempre será susceptible de ordenarse según diferentes criterios. Un algoritmo de ordenación (tal como QuickSort) puede trabajar con cualquier tipo de elementos (números, cadenas, objetos, etc.) pues lo único que requieren para funcionar es saber cuando un elemento es menor que otro, es decir, sólo necesitan saber cómo comparar dos elementos. Esto es lo que sucede con CustomSort. A este método, le pasamos una función que compara dos elementos. Internamente, CustomSort tendrá que llevar a cabo muchas comparaciones dos a dos, y tal comparación la hará utilizando la función que le pasamos. Espero que te haya aclarado algo. // Saludos |
La franja horaria es GMT +2. Ahora son las 04:22:55. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi