🚀PROMO #PLANCARRERA2024 - 🔥Bonificaciones, Precios Congelados y Cuotas

 X 

✒️ABAP Los cortes de control utilizando tablas internas

ABAP Los cortes de control utilizando tablas internas

ABAP Los cortes de control utilizando tablas internas

Contre de control: es un a forma de estructurar un reporte de salida por pantalla de modo de poder sumarizar datos y mostrar totales por distintos campos del reporte.

Supongamos que tenemos que generar un reporte de cliente por región y distrito, en donde se muestre por cada regíon y distrito, los clientes existentes juntos con sus importes.

También se desea mostrar el importe total del cliente, el importe total por distrito y el importe total por región.

Luego de aplicar la técnica de corte de control la salida por pantalla del reporte de cliente

A continuación vamos a aprender a implementar los cortes de control en nuestros reportes ABAP.

El paso a paso para implementar uncorte de control:son una técnica, se encuentra compuesta por una serie de pasos que debemos seguir para que funcione correctamente.

Vamos a analizar detalladamente todos los pasos que debemos seguir para implementar cortes de contol.

Para ello vamos a tomar como ejemplo el Reporte de Clientes por Región y Distrito

Lo primero es declarar la tabla interna de salida del reporte. el orden en el que se declaran los campos en la tabla interna va a ser el mismo orden en el que se desea que esos campos se visualicen en pantalla.

Para nuestro reporte de clientes por rehión y distrito declaramos la tabla interna de salida TI_CLIENTES y la estructura o área de trabajo WA_CLIENTES de la siguiente forma:

* Tipo de datos

TYPES: BEGIN OF ty_clientes,

region (10) TYPE c,

distrito (10) TYPE c,

nrocliente (5) TYPE c,

importe TYPE i,

END OF ty-clientes.

*Tabla interna y estructura

DATA: ti_clientes TYPE STANDARD TABLE OF ty_clientes,

wa_clientes LIKE LINE OF ti_clientes.

Por una particularidad de ABAP vamos a necesitar declara siempre una estructura auxiliar, cuyo nombre será WA_CLIENTES_AUX, a aparte de la que ya declaramos al momento de declarar la tabla interna.

DATA: wa_clientes_AUX LIKE LINE OF ti_clientes.

Por último, vamos a declarar una variable de tipo I para cada uno de los importes que deseamos sumarizar. es desir, vamos a declarar las variables V_IMPORTE_TOTAL_REGION V_IMPORTE_TOTAL_DISTRITO y V_IMPORTE_TOTAL_CLIENTE.

DATA: v_importe_total_cliente TYPR i,

v_importe_total_distrito TYPE i,

v_importe_total_region TYPE i.

Ahora bien, luego de declarar todas las variables necesarias, vamos primeramente a borrar el contenido de la tabla interna TI_CLIENTES. Para prevenir situaciones erróneas ejecutamos el REFRESH de la tabla interna TI_CLIENTES.

A continuación, vamos a proceder con el llenado del contenido de la tabla interna TI_CLIENTE para ello vamos a cargar cada uno de los registros de datos de la tabla interna completando los campos REGION, DISTRITO, NROCLIENTE e IMPOERTE.

Luego lo que vamos a necesitar es ordenar la tabla interna TI_CLIENTES por los campos por los cuales se van a realizar el corte de control. En este caso tenemos que ordenar por REGION, DISTRITO y NROCLIENTE. Recordemos que si en la ejecución de la sentencia SORT no especificamos el tipo de ordenamiento entonces el mismo por defecto se realizará en forma ascendiente.

*-----------------------------------------------------------------------------*

*Ordenamos la tabla interna

*------------------------------------------------------------------------------*

SORT ti_clientes BY region distrito nrocliente.

A continuacion vamos a recorrer la tabla interna TI_CLIENTES y es aquí dentro de este LOOP-ENDLOOP en donde se realiza el corazon de la técnica de corte de control.

Una vez dentro del LOOP lo primero que vamos a hacer y que es sumamente importante es pasar el contenido de la estructura o área de trabajo WA_CLIENTES a WA_CLIENTES_AUX.

*-----------------------------------------------------------------------------*

*Recorremos la tabla interna

*-----------------------------------------------------------------------------*

LOOP AT ti_clientes INTO wa_clientes.

Copiamos el contenido del rtegistro a una estructura auxiliar

CLEAR wa_clientes_aux.

wa_clientes_aux = wa_clientes.

Para realizar un corte de control, ABAP pone a nuestra disposición dos sentencias que nos facilita el trabajob como programadores.

La sentencia AT NEW campo se ejecuta por cada valor nuevo que se encuentre almacenada en campo. Mira hacia atrás, es descir compara el contenido del campo del registro actual de la tabla interna que se esta procesando contra el cotenido del campo del registro anterior de la tabla interna que se procesó.

  • Si el resultado de esa comparación es que los contenidos de ambos campos son diferente entonces se ejecuta la lógica ABAP que se encuentra dentro del AT NEW.

  • Si el resultado de esa comparación es que los contenidos de ambos campos son iguales entonces no ejecuta la lógica ABAP que se encuentra dentro del AT NEW.
  • Si estamos presentando el primer registro de la tabla interna entonces compara el contenido del campo contra nada y el resultado de esa comparaciíon es que son distintos por lo que se ejecuta la lógica ABAP que se encuentra dentro del AT NEW

Y la sentencia AT END OF campo mira hacia adelante, es decir compara el contenido del campo del registro autual de la tabla interna que se está procesando contra elcontenido del campo del registro siguiente de la tabla interna que todavia no se procesó.

  • Si el resultado de esa comparación es que los contenidos de ambos campos son diferente entonces se ejecuta la lógica ABAP que se encuentra dentro del AT END OF.
  • Si el resultado de esa comparación es que los contenidos de ambos campos son iguales entonces no ejecuta la lógica ABAP que se encuentra dentro del AT END OF.
  • Si estamos presentando el primer registro de la tabla interna entonces compara el contenido del campo contra nada y el resultado de esa comparaciíon es que son distintos por lo que se ejecuta la lógica ABAP que se encuentra dentro del AT END OF.

Si volvemos a nuestro reportes de clientes por región y distrito entnces implementaremos de la siguente forma esta sentencia.

Por cada nueva región vamos a ejecutar un AT NEW REGION y aqie dentro vamos a haceder dos puntos fundamentales que se inicializar la variable V_IMPOTE _TOTAL_REGION que sumariza el importe por región e imprimer la región que estamos procesando.

*--------------------------------------------------------------*

* Por cada nueva región

*--------------------------------------------------------------*

AT NEW region.

clear v_importe_total_region.

FORMAT COLOR 1.

WRITE:/ sy-uline (83).

WRITE:/ 'Región:', wa_clientes_aux_region.

WRITE:/ sy-uline (83).

ENDAT.

Por cada nuevo distrito a ejecutar un AT NEW DISTRITO y aqui dentro vamos a hacer dos puntos fundamentales que son inisializar la variable V_IMPORTE _TOTAL_DISTRITO que sumariza el importe por distrito e imprimir el ditrito que estamos procesando.

*--------------------------------------------------------------*

* Por cada nueva distrito

*--------------------------------------------------------------*

AT NEW distrito.

clear v_importe_total_distrito.

FORMAT COLOR 5.

WRITE:/ 10 'distrito:', wa_clientes_aux_distrito.

ENDAT.

Por cada nuevo número de cliente vamos a ejecutar un AT NEW NROCLIENTE y aqui dentro vamos a inicializar la variable V_IMPORTE_TOTAL_CLIENTE que sumaria el importe por cliente.

*--------------------------------------------------------------*

* Por cada nueva distrito

*--------------------------------------------------------------*

AT NEW distrito.

clear v_importe_total_distrito.

FORMAT COLOR 5.

WRITE:/ 10 'distrito:', wa_clientes_aux_distrito.

ENDAT.

Una vez que se ejecutaron cada uno de los AT NEW entonces fuera de ellos será nesesario sumarizar o acumular cada uno de los importes que mostramos a continuación en el reporte.

* Acumulamos los importes

ADD wa_clientres_aux-importe TO v_importe_total_cliente.

ADD wa_clientres_aux-importe TO v_importe_total_distrito.

ADD wa_clientres_aux-importe TO v_importe_total_region.

Luego vamos a imprimir el total de cliente. esto lo vamos hacer cuando se ejecute el último registro correspondiente al número de cliente que estemos procesamdo.

Para ello vamos a ejecutar la sentencia AT END NROCLIENTE y en caso de ser el último número de cliente se ejecuta la lógica que se encuentra dentro del END OF, que consisste básicamente en imprimir en pantalla el número de cliente y el importe total acumulado por cliente tal como vemos a continueción

*--------------------------------------------------------------*

* Imprimimos total por cliente

*--------------------------------------------------------------*

AT END OF nrocliente.

FORMAT COLOR 3.

WRITE:/ 30 'cliente:', wa_clientes_aux_nrocliente,

50 'Importe Toltal Clientes', v_importe_total_cliente.

ENDAT.

Luego vamos a imprimir el total por distrito. esto lo vamos hacer cuando se ejecuta el último registro corespondiente al distrito que estamos procesando.

Para ello vamos a ejecutar la sentencia AT AND OF DISTRITO y en caso de ser el último distrito se ejecutará la lágica que se encientra dentro del AT END OF, que consiste básicamente en imprimir en pantalla el importe total acumulado por distrito tal como vemos a continuación.

*--------------------------------------------------------------*

* Inprimimos todo por distrito

*--------------------------------------------------------------*

AT END OF distrito.

FORMAT COLOR 5.

WRITE:/ 10 'Importe Total distrito', v_importe_total_distrito.

ENDAT.

Y por último vamos a imprimir el total por región. esto lo vamso hacer cuando se ejecute el último registro correspondiente a la región que estamos procesando.

Para ello vamos a ejecutar la sentencea del AT END OF, que consiste básicamente en imprimir en pantalla el importe total aculado por región tal como vamos a continuación:

*--------------------------------------------------------------*

* Inprimimos todo por region

*--------------------------------------------------------------*

AT END OF region.

FORMAT COLOR 1.

WRITE:/ 'Importe Total region', v_importe_total_region.

ENDT.

ENDLOOP.


 

 

 


Sobre el autor

Publicación académica de Javier Miguel Angel Barcelo, en su ámbito de estudios para la Carrera Consultor ABAP.

Javier Miguel Angel Barcelo

Profesión: Militar - Argentina - Legajo: DQ34X

✒️Autor de: 31 Publicaciones Académicas

🎓Cursando Actualmente: Consultor ABAP Nivel Inicial

Certificación Académica de Javier Angel

✒️+Comunidad Académica CVOSOFT

Continúe aprendiendo sobre el tema "Los cortes de control utilizando tablas internas" de la mano de nuestros alumnos.

SAP SemiSenior

Cortes de control con tablas internas. Puedo realizar el corte segun el acumulado que desee realizar muy util. utilizando sentencias at.

Acceder a esta publicación

Creado y Compartido por: Christian Camilo Alzate Duque

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP SemiSenior

Cortes de control utilizando tablas internas. En este ejemplo ilustran la manera de hacer cortes de control los pasos a seguir son. 1. Cargar tabla interna con distintos registros. 2. Ordenar la tabla interna según orden que se quiere que se visualicen los datos. 3. Recorrer la tabla para realizar listado. 4. Dentro del LOOP se deben pasar los datos que se están recorriendo a una estructura auxiliar. 5. AT NEW compara los campos por los cuales se desea realizar el corte de control. 6. Se acumulan los valores por los cuales se quieren sumar, contar. 7. Para la impresión de los datos se utiliza la sentencia AT END seguida del campo por el cual se realiza el corte.

Acceder a esta publicación

Creado y Compartido por: Fabio Gallo

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Master

video para crear cortes de control utilizndo tablas internas. con la sentencia AT NEW se realiza el corte de control.

Acceder a esta publicación

Creado y Compartido por: Rainer Diaz

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

Unidad 3 - 2 - Cortes de control utilizando tablas internas en reportes. Los cortes de control son utilizados para la generacion e listados, utilizando la sentencia AT. **Antes de realizar el corto de control dentro de un loop. Debemos pasar los datos que se estan recorriendo a una estructura auxiliar.. Esto se debe a que ABAP complete con * todos los campos a la derecha del campo por el cual realizamos el corte.corte. AT NEW: INternamente compara el actual campo con el valr anterior. Si estos son disitntos entonces se preocesa el codigo que esta dentro del AT NEW. AT END: para realizar la impresion de los datos, utilizamos la sentencia AT END. Intermente compara el campo actual con el proximo, si estos son disitintos entonces se procesara...

Acceder a esta publicación

Creado y Compartido por: Matias Ciutat

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

Cortes de control utilizando tablas internas en reportes. Veremos como realizar corte de control a una tabla interna para poder imprimir un listado por pantalla. una tabla interna con Registro de clientes que incluyen un importe entre los campos. Y queremos obtener un listado de clientes donde se muestre una solo linea el total por clientes. En este caso se realizaría un corte de control por cada nuevo cliente y un corte para imprimir los resultados. Cargar tabla de clientes con diferentes registros. Abap completa con asteriscos todos los campos a la derecha del campo por el cual hacemos el corte. Sentencia AT NEW= compara el actual numero de cliente con el anterior numero de cliente. en caso de ser distintos se procederá....

Acceder a esta publicación

Creado y Compartido por: Rafael Razo

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

- Cortes de control utilizando tablas internas Corte de control: Forma de estructurar un reporte de salida de modo de poder sumarizar datos y mostrar totales por distintos campos del reporte. Una condición importante de los cortes de control es que la tabla de salida del reporte debe ordenarse por los campos que se realiza el corte de control. Es indispensable usar una tabla auxiliar para almacenar los datos del registros de la tabla interna, ya que ABAP llenará con asteriscos los campos que se encuentren a la derecha del campo por el que se realiza el corte y se perderá la info almacenada en ellos. AT NEW <campo> : Compara el valor actual del campo con el anterior, si es distinto entonces se procesa el código...

Acceder a esta publicación

Creado y Compartido por: Sandra Erika Bernabe Abreu

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

Cortes de control utilizando tablas internas Corte de control: Estructurá un reporte de salida para poder sumarizar datos y mostrar totales por distintos campos del reporte. Una condición importante de los cortes de control es que la tabla de salida del reporte debe ordenarse por los campos que se realiza el corte de control. Es indispensable usar una estructura auxiliar para almacenar los datos del registros de la tabla interna, ya que ABAP llenará con asteriscos los campos que se encuentren a la derecha del campo por el que se realiza el corte y se perderá la info almacenada en ellos. AT NEW <campo> : Compara el valor actual del campo con el anterior, si es distinto entonces se procesa el código...

Acceder a esta publicación

Creado y Compartido por: Miguel Mauricio Sierra Cardona

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

Cortes de control utilizando tablas internas Corte de control: Forma de estructurar un reporte de salida de modo de poder sumarizar datos y mostrar totales por distintos campos del reporte. Una condición importante de los cortes de control es que la tabla de salida del reporte debe ordenarse por los campos que se realiza el corte de control. Es indispensable usar una tabla auxiliar para almacenar los datos del registros de la tabla interna, ya que ABAP llenará con asteriscos los campos que se encuentren a la derecha del campo por el que se realiza el corte y se perderá la info almacenada en ellos. AT NEW <campo> : Compara el valor actual del campo con el anterior, si es distinto entonces se procesa el código...

Acceder a esta publicación

Creado y Compartido por: Juan Rodrigo Meza Avina

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

CORTES DE CONTROL UTILIZANDO TABLAS INTERNAS: Para hacer un corte de control tenemos que seguir los siguientes pasos: Cargar la tabla interna. Ordenar la tabla segun el orden que queramos, esto lo hacemos con la sentencia SORT. Se recorre la tabla interna para realizar el listado. Esto lo haremos con la sentencia LOOP AT. Antes de realizar el corte debemos pasar los datos a una estructura auxiliar. Se realiza el corte con la sentencia AT NEW que compara el valor del campo actual con el del campo anterior y si son distintos se procesa el codigo de AT NEW. Usamos ADD TO para acumular los importes. Para imprimir los datos usamos AT END seguida del campo por el cual hacemos el corte, que compara el campo actual con proximo...

Acceder a esta publicación

Creado y Compartido por: Gema Moreno Ferreiro

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Expert


CORTES de CONTROL Es un forma de estructurar un reporte de salida de modo de poder sumar campos y poder mostrar totales por los campos seleccionados del reporte. Una condición esencial para los cortes de control es que la tabla debe estar ordenada por los campos a los cuales se le va a realizar el corte de control. Es indispensable utilizar una estructura auxiliar para almacenar los datos internos del registro . Se va a utilizar la sentencias: AT NEW <campo> Esta compara el valor anterior del campo con el valor actual, si es diferente entonces se procesará lo que esta en AT NEW AT END <campo> Compara el valor actual con el valor siguiente, si son diferente se procesará el código del AT END. Se puede realizar...

Acceder a esta publicación

Creado y Compartido por: Maria Guadalupe Gonzalez Sanchez

 


 

👌Genial!, estos fueron los últimos artículos sobre más de 79.000 publicaciones académicas abiertas, libres y gratuitas compartidas con la comunidad, para acceder a ellas le dejamos el enlace a CVOPEN ACADEMY.

Buscador de Publicaciones:

 


 

No sea Juan... Solo podrá llegar alto si realiza su formación con los mejores!