|
#1
|
|||
|
|||
Problema con loop
Hola!!
Tengo un loop a una tabla, pero cada vez que se va procesando, no me mete en la cabecera el registro que corresponde, por orden, si no que me mete cada vez uno al azar. Sabéis por qué puede ser? Este es el código PROCESS AFTER INPUT. "Comprobación de qué filas del table control se han seleccionado LOOP AT datos_cliente. MODULE contador. "Lo hago para incrementar cada vez el sy-tabix, puesto que siempre vale 1 chain. field: COL_SELECC. MODULE seleccionar ON CHAIN-REQUEST. endchain. ENDLOOP. Gracias!!! |
#2
|
|||
|
|||
La IT esta ordenada? fijate xq a lo mejor te olvidaste un SORT son cosas q pasan... Cualquier cosa chifla
|
#3
|
|||
|
|||
Hola.
Sí, la tabla está ordenada, por eso me parece tan raro que no me vaya por orden cuando la voy procesando. |
#4
|
||||
|
||||
Hola Lucia, el sy-tabix no necesariamente siempre es 1, depende del registro en el cual se direcciona en el LOOP, y en que MODULE asignas de cabecera a tabla interna?? en contador? o seleccionar?
__________________
David Carballido Córdova |
#5
|
|||
|
|||
Sí que es verdad que el sy-tabix va variando según el registro, pero en este caso concreto no cambia, por eso hago el module contador.
Cuando debugueo paso a paso, al entrar la primera vez en el loop, veo que en la cabecera no me ha metido el primer registro que hay en datos_cliente, si no otro. En seleccionar cambio unos datos del registro que se está tratando y hago un modify...index..., pero al no cogerme la tabla interna por orden, me añade un nuevo registro a la tabla. No sé si me he explicado bien... |
#6
|
||||
|
||||
Trata de hacerle el MODIFY pero con el INDEX de la tabla de control, algo asi
MODIFY itab INDEX tctrl-current_line. Tal vez sea x eso ...
__________________
David Carballido Córdova |
Herramientas | Buscar en Tema |
Desplegado | |
|
|