![]() |
Error de variable en bucle for
Buenas a todos.
Estoy tratando de usar un bucle for para añadir automaticamente n registros a una tabla, pueden ir de uno a 150 aproximadamente y claro al hacerlo a mano siempre tenemos la posibilidad de olvidarnos de uno, de repetir otro, etc. Para esto he intentado armar el siguiente bucle:
Al compilar me da esto: [Error] Real.pas(776): For loop control variable must be simple local variable He colocado la variable donde está, en la declaracion public, en var del formulario y nada, siempre el mismo error. Alguien me puede echar un cable? y de pasada me podeis decir si el código es correcto o necesitaria alguna modificacion. El identificador único ID ya se lo paso en el evento onnewrecord de la tabla al igual que otro campo que es fijo ID_SERIE. Gracias por adelantado Josep |
|
Gracias, tiene toda la razón había olvidado los dos puntos, el código modificado queda así:
Saludos Josep |
Buenas de nuevo.
Sigo dando palos al agua con el bucle contador, acumulador, generador o como quiera llamarse. Este es el código que funciona "a medias" si el length de (a) es 1, no hay problema, pero si el length es 2, el resultado obtenido no es el deseado.
Lo que obtengo: 269.501 269.502. . . . 269.5010 269.5011 . . 269.5022 Lo que necesito 269.501 269.502 . . . 269.510 269.511 . . . 269.522 Tambien me encuentro con series en que la primera unidad es la 201 pero hay 133, con lo que tambien deberia cambiar la centena, es decir 269.201,.... 269.299,.... 269.300,.....269.333 No se estoy un poco perdido. Seguro que hay algun metodo para poder realizar este contador pero.... Gracias por leerme Saludos Josep |
Hola Josep.
Por lo que pude inferir deseas componer un código compuesto por: Los primeros tres dígitos del número de serie, mas un punto, mas un código consecutivo de tres dígitos. Te pongo un ejemplo que realiza esa tarea para que lo adaptes a tu código: Para probar el ejemplo sólo agrega un TListBox y un TButton en un TForm. Saludos :) |
Muchas gracias ecfisa.
El código genera 500 valores con el formato que yo quiero, esto es perfecto aunque no entiendo muy bien la linea:
No acabao de ver claro como implemento esto en mi código ya que aunque las series siempre constan de tres digitos, tengo varios escenarios: Serie de 3 numeros sin subserie (ejemplo 309) y 20 ejemplares los codigos deben empezar por 309.001 y llegar al 309.020. Serie de 3 numeros con subserie (ej. 269.2) y 131 ejemplares los códigos deben empezar por 269.201 y llegar al 269.331. Serie de 3 numeros con subserie (ej. 269.5) y 22 ejemplares los códigos deben empezar por 269.501 y llegar al 269.522. Como es estos datos son variables debo controlarlos antes de generar los registros de la tabla, yo se de antemano ya que estan en la tabla el valor de la serie y el numero de unidades. Ahora he hecho una "chapuza" que funciona:
aunque así me genera los registros pero creo que debe haber una solucion más fácil al problema. Voy a dar alguna vuelta más a tu función a ver si le saco el entresijo. Saludos Josep |
Hola Josep.
Entiendo que el valor máximo del for (Total) se encuentra en Tren_RealUNITATS_CONSTRUIDES.Value y el código de serie en Tren_RealID_SERIE.Value. Aplicando a tu código lo que te sugerí en el mensaje #5, debería quedar algo parecido a: (Tomá en cuenta que lo hice en el aire y puede tener algún error) Saludos :) |
Gracias de nuevo.
No acabo de hacerlo funcionar, aunque creo que no se acaba de ajustar a las distintas posibilidades que tengo. Como lo hago si debo empezar a contar en el 201 en vez del 001? No se, me voy a comer y luego continúo. Saludos Josep |
Hola Josep.
Cita:
Saludos :) |
De nuevo gracias.
Me has dado una idea que no se si la puedo implementar correctamente. Como se que la subserie empieza por un dígito concreto, puedo crear un campo que sea por ejemplo 500 y sumarle tantos valores como unidades tenga. Pero y si el dígito inicial es 0? Lo tendré que tratar como una cadena? Cada vez el lio es mayor Quiero automatizarlo al máximo, ya que si quien hace la operación no soy yo y empieza el sistema a pedir valores iniciales etc, se puede liar gorda. Saludos Josep |
Hola Josep.
Cita:
completa con ceros delante hasta lograr las tres cifras, vg.: Código:
1 = 001 Cita:
Es decir, yo te entendí que el nuevo código está formado por tres partes que son:
Saludos :) |
Gracias de nuevo.
Te explico: Es decir, yo te entendí que el nuevo código está formado por tres partes que son:
Lo que puedo encontrar es que alguna subserie supere la centena con lo que se empieza en la centena siguiente como expliqué en un post anterior, empiezo en la 201 y acabo en la 331, en realidad la subserie 300 no existe es continuacion de la 200 No se si me he explicado bien. Con el código que solté en el otro post me genera bien los códigos. Saludos Josep |
Hola Josep.
A ver si entendí...
Ejemplo de uso: En el ejemplo, generaría este resultado: Código:
567.300 Saludos :) |
La franja horaria es GMT +2. Ahora son las 09:24:41. |
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