FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Comparacion y validacion en Delphi
Hola, bendiciones para todos.
En la universidad me pusieron hacer un programa donde debo validar y comparar varios edit. Coloco el formulario para que tengan una idea. https://drive.google.com/open?id=1Nc...HvA21lWAj4F3KL Explicare lo que debe hacer el programa. Si por ejemplo en la columna 1 fila 10 yo coloco los valores 10 50 70 y en la columna 4 fila 35 coloco esos mismos valores en ese mismo orden me tiene que salir un mensaje que diga que esa combinacion de numeros esta siendo utilizada. He intentado hacerlo con IF pero seria muchas condiciones. Apelo a ustedes para ver de que otra forma se podria hacer. Gracias de antemano |
#2
|
||||
|
||||
has probado con concatenar las lineas y luego preguntar?
algo asi
y luego
__________________
Dulce Regalo que Satanas manda para mi..... |
#3
|
||||
|
||||
Cita:
Lo primero es poner nombres "adecuados" a los controles TEdit que hay en el formulario. Lo segundo es, que como biien dices, intentar hacerlo copn IF te dará un número de condiciones muy grande (inviable). Puedes acceder a un componente utilizando su nombre utilizando algo similar a lo siguiente:
Si combinas esto con un bucle FOR y los índices correctos, podrás acceder a todos los Edits. No se si me he explicado. Si es que no coméntalo y te podemos añadir un ejemplo más explicativo.
__________________
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. |
#4
|
||||
|
||||
Cada vez que el usuario termine de llenar (o cambiar) una terna, deberás comparar contra todas las demás para ver si está repetida. Eso de inmediato sugiere un ciclo en donde la terna se compara con cada una de las otras. Esto implica un múltiple recorrido de todos los controles. Para facilitar eso, yo declararía un arreglo de todos los Edits:
E inicializaría el arreglo en el constructor del formulario:
De esta forma evitas tener que referirte a los controles por su nombre. Esto puede ser costoso porque métodos como FindComponent lo que hacen de por sí es un ciclo por todos los componentes del formulario en busca de uno con el nombre dado. Esto, multiplicado por todas la veces que vas a tener que acceder al control para comparar podría ser un camino muy largo. Para hacer la comparación, puedes implementar una función de comparación en un ciclo:
Esto lo escribo al vuelo así que puede estar incorrecto, pero es para dar la idea. // Saludos |
#5
|
|||
|
|||
Hola, bendiciones para todos. Agradezco sus opiniones, las cuales han sido de gran ayuda. Les cuento.
He tomado la idea de Oscarac, pero lo he hecho con arreglos. Ejemplo: Declare un arreglo
Luego los llene concatenando las lineas (que contienen 3 edit cada linea)
y con un FOR recorro los arreglos haciendo la comparacion
Esta solucionado, gracias a ustedes. Pero me gustaria agregarle algo, y es que cuando encuentre una similitud, me gustaria saber en que columna y fila ya se habia introducido la combinacion de numero, ya sea, resaltando en color los edits que contienen los numeros. |
#6
|
||||
|
||||
Para evitar esto, es justo para o que sirve el FindComponent. Te lo pongo de memoria, pero la idea sería algo así:
Y abreviando un poco más...
__________________
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. |
#7
|
||||
|
||||
Cita:
- Ordena, organiza y busca - Usa la estructura de datos correcta que facilite lo de arriba Si estuvieras haciendo esto con SQL la respuesta seria muy obvia. Pon todo en una "tabla": Código:
Col Row Values 1 1 10 50 70 4 35 10 50 70 E incluso, te hace pensar: Podria hacerlo mejor? Siguiendo con la idea de inspirarse con bases de datos, como se hace una búsqueda en una BD? Con un indice. Como podrías "indexar" estos datos?: Código:
Key Position 10 50 70 [1 1,4 35]
__________________
El malabarista. |
#8
|
||||
|
||||
Cita:
// Saludos |
#9
|
|||
|
|||
Cita:
Use esa logica para limpiar los edit de la siguiente manera:
Pero no he logrado hacerlo para concatenar las cadenas |
#10
|
||||
|
||||
Cita:
Pues al final se trata de conseguir el nombre del componente correcto, utilizando FindComponent, tal y como has hecho aquí. El resto de código sea para limpiar, concatenar, o lo que sea es independiente.
__________________
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. |
Herramientas | Buscar en Tema |
Desplegado | |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Comparacion de Hash MD5 Delphi-Oracle no coincide | marvajes | Conexión con bases de datos | 1 | 13-11-2015 21:27:59 |
Ayuda Comparacion. | Paco Fernandez | Varios | 4 | 28-04-2012 13:55:01 |
comparación de text | lisc_dla | Varios | 2 | 02-08-2011 20:04:15 |
Comparación de Fechas | sierraja | Varios | 5 | 19-06-2005 06:56:20 |
Validación en Delphi. | Ana Iris Guille | Varios | 3 | 30-06-2003 17:25:02 |
|