PROMO JULIO en CVOSOFT United States Of America: 💎Calidad, 🔥Bonificaciones, 🥶Precios Congelados y MÁS!

 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

Los cortes de control utilizando tablas internas

1. ¿Qué es un Corte de control?

Es una forma de estructurar un reporte de salida por pantalla de modo de poder sumarizar datos y mostrar totales por distintos campos del reporte.

2. El paso a paso para implementar un corte de control

Los cortes de control en definitiva son una técnica y como toda técnica, se encuentra compuesta por una serie de pasos que debemos seguir para que funcione correctamente. Se tomará de ejemplos el "Reporte de Clientes por Región y Distrito".

Lo primero que se necesita es declarar la tabla interna de salida del reporte. La particularidad que tendrá esta tabla es que va a estar compuesta por cada uno de los campos que se desean incluir en el reporte de salida y el orden en el que se declaran los campos en la tabla interna será el mismo orden en el que se desea que esos campos se visualicen en pantalla. Declaramos la tabla interna TI_CLIENTES y la estructura WA_CLIENTES.

Código de ejemplo:

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 se necesita declarar una estructura auxiliar, el nombre será WA_CLIENTES_AUX.

Código de ejemplo:

DATA: wa_clientes_aux LIKE LINE OF ti_clientes.

Se declara la variable de tipo I para cada unio de los importes que deseamos sumarizar.

Código de ejemplo:

DATA: v_importe_total_clientes TYPE i,

v_importe_total_distrito TYPE i,

v_importe_total_region TYPE i.

Es una buena práctica de programación borrar la tabla interna, de este modo aseguramos que no hay contenido y que no habrá errores en la ejecución del reporte. Recordamos que esto se hacía con REFRESH. Una vez hecho esto se llena la tabla interna con contenido.

Código de ejemplo:

REFRESH ti_clientes.

CLEAR ti_clientes.

wa_clientes-region = 'CAPITAL'.

wa_clientes-distrito = 'Caballito'.

wa_clientes-nrocliente = '00001'-

wa_clientes-importe = 30.

APPEND wa_clientes TO ti_clientes.

Luego se necesita que la tabla interna TI_CLIENTES sea ordenada por los campos por los cuales se va a realizar el corte de control. En este caso habrá que ordenarlo por REGION, DISTRITO y NROCLIENTE. Para ordenador recordemos que se usa la sentencia SORT y si no se especifica el tipo de ordenamiento por defecto se realizará en forma ascendente.

Código de ejemplo:

SORT ti_clientes BY region distrito nrocliente.

Vamos a recorrer la tabla interna TI_CLIENTES y es aquí donde dentro de este LOOP-ENDLOOP en donde se realiza el corazón 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.

Código de ejemplo:

* Recorremos la tabla interna

LOOP AT ti_clientes INTO wa_clientes.

* Copiamos el contenido del registro a una estructura auxiliar.

CLEAR wa_clientes_aux

wa_clientes_aux = wa_clientes.

Ahora viene la parte más importante de la técnica de corte de control. ABAP pone a nuestra disposición dos sentencias que nos facilitan el trabajo como programadores para realizar un corte de control, la sentencia AT NEW cuya sintaxis es la siguiente:

AT NEW CAMPO.

....

ENDAT.

La sentencia AT NEW campo se ejecuta por cada valor nuevo que se encuentra almacenado en el campo. Esta sentencia mira hacia atrás, es decir, compara el contenido del campo del registro actual de la tabla interna que se está procesando contra el contenido del campo del registro anterior de la tabla interna que se procesó.

Si el resultado de esa comparación es que lo los contenidos de ambos campos son diferentes, entonces se ejecutara 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 se ejecuta la lógica ABAP que se encuentra dentro del AT NEW.

Si estamos procesando el primer registro de la tabla interna, entonces compara el contenido del campo contra nada y el resultado de esa comparación es que son distintos, por lo que se ejecuta la lógica ABAP que se encuentra dentro del AT NEW.

Luego tenemos la sentencia AT END OF campo. Esta sentencia se ejecuta cuando se está procesando el último registro que tenga almacenado un valor determinado de ese campo.

La sentencia AT END OF campo mira hacia adelante, es decir, compara el contenido del campo del registro actual de la tabla interna que se está procesando contra el contenido del campo del registro siguiente de la tabla interna que todavía no se procesó.

Si el resultado de esta comparación es que los contenidos de ambos campos son diferentes, 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 se ejecuta la lógica ABAP que se encuentra dentro del AT END OF.

Si estamos procesando el último registro de la tabla interna, entonces comparará el contenido del campo contra nada y el resultado de esa comparación es que son distintos, por lo que se ejecuta la lógica ABAP que se encuentra dentro del AT END OF.

Volviendo a nuestro reporte, deberíamos de implementar de la siguiente manera estas sentencias:

Por cada nueva región vamos a ejecutar un AT NEW REGION y aquí dentro vamos a hacer dos puntos fundamentales que son inicializar la variable V_IMPORTE_TOTAL_REGION que sumarizara el importe por región e imprimir la región que estamos procesando.

Código de ejemplo:

* Por cada nueva región

AT NEW region.

CLEAR v_importe_total_region.

FORMAT COLOR 1.

WRITE:/ s-uline(83).

WRITE:/ 'Region:', wa_clientes_aux-region.

WRITE:/ sy-uline(83).

ENDAT.

Por cada nuevo distrito vamos a ejecutar un AT NEW DISTRITO e igual que antes es fundamental inicializar la variable V_IMPORTE_TOTAL_DISTRITO que sumariza el importe por distrito.

Código de ejemplo:

* Por cada nueva región

AT NEW distrito.

CLEAR v_importe_total_distrito.

FORMAT COLOR 5.

WRITE:/ s-uline(83).

WRITE:/ 'Distrito:', wa_clientes_aux-distrito.

WRITE:/ sy-uline(83).

ENDAT.

Por cada nuevo número de cliente vamos a ejecutar un AT NEW NROCLIENTE e igual que antes es fundamental inicializar la variable V_IMPORTE_TOTAL_NROCLIENTE que sumariza el importe por cliente.

Código de ejemplo:

AT NEW nrocliente.

CLEAR v_importe_total_nrocliente.

FORMAT COLOR 10.

WRITE:/ s-uline(83).

WRITE:/ 'Distrito:', wa_clientes_aux-nrocliente.

WRITE:/ sy-uline(83).

ENDAT.

Una vez ejecutados los AT NEW será necesario sumarizar o acumular cada uno de los importes que mostraremos a continuación en el reporte.

Código de ejemplo:

ADD wa_clientes_aux-importe TO v_importe_total_cliente.

ADD wa_clientes_aux-importe TO v_importe_total_distrito.

ADD wa_clientes_aux-importe TO v_importe_total_region.

Luego imprimimos el total por cliente, por distrito y por región, el primero esto se hará cuando se ejecute el último registro correspondiente al número de cliente que estamos procesando, el segundo cuando se ejecute el último registro correspondiente al distrito y el tercero cuando se ejecute el último registro de región.

Para ello vamos a ejecutar la sentencia AT END OF CLIENTE (luego seria con AT END OF DISTRITO y AT END OF REGION) y en caso de ser el último número de cliente (distrito o región) se ejecutará la lógica que se encuentra dentro del AT END OF, que consiste básicamente en imprimir en pantalla el número de cliente (distrito o región) y el importe total acumulado por cliente (distrito o región) tal como vemos a continuación.

Código de ejemplo:

* Imprimimos total por distrito

AT END OF distrito.

FORMAT COLOR 5.

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

ENDAT.


 

 

 


Sobre el autor

Publicación académica de Alexander Antelo Garcia, en su ámbito de estudios para la Carrera Consultor ABAP.

SAP Senior

Alexander Antelo Garcia

Profesión: Ing. en Sistemas de la Informacion - Mexico - Legajo: KR64D

✒️Autor de: 44 Publicaciones Académicas

🎓Egresado del módulo:

Certificación Académica de Alexander Garcia

✒️+Comunidad Académica CVOSOFT

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

SAP Master


LECCION 2. UNIDAD 3. CORTES DE CONTROL UTILIZANDO TABLAS INTERNAS. Abap cortes de control utilizando tablas internas: cuando se trabaja realizando reportes, se puede presentar la necesidad de ordenar la tabla interna de salida del reporte, de una determinada forma en donde se agrupen los datos a mostrar en la pantalla. Para realizar cortes de control se utilizan las sentencias que se relacionan a continuación: AT NEW: esta sentencia comparara el actual valor del campo con el valor anterior, en caso de ser distintos entonces se procesara el código dentro del AT NEW. AT END: esta sentencia comparara el actual valor del campo con el valor siguiente, es decir el que se encuentra en la proxima vuelta de la tabla interna. En caso de...

Acceder a esta publicación

Creado y Compartido por: Jose Dario Angel Vanegas

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

SAP Expert


En ABAP, los cortes de control utilizando tablas internas son una técnica útil para organizar y resumir datos de manera jerárquica o agrupada. Los cortes de control permiten realizar cálculos o análisis específicos en grupos de datos y mostrar los resultados de manera estructurada. Esta técnica es comúnmente utilizada para generar informes o listados que presentan datos de manera organizada y resumida.Final del formulario Los cortes de control utilizando tablas internas en ABAP son una técnica poderosa para organizar y resumir datos de manera eficiente. Esta técnica permite generar informes y análisis más legibles y comprensibles, especialmente cuando se manejan...

Acceder a esta publicación

Creado y Compartido por: Darling Geraldino

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

SAP Master

CORTES DE CONTROL UTILIZANDO TABLAS INTERNAS Estructura un reporte, de modo de poder sumarizar datos y mostrarlos por distintos campos del reporte, proceso. Cargar las tablas internas con distintos registros Ordenar las tablas Recorrer las tablas para visualizar el listado Para realizar el corte de control por cliente utilizamos las siguientes sentencias: AT NEW <campo>. Compara el actual numero del cliente con el anterior, si son distintos el codigo se procesa dentro del AT NEW AT END <campo>. Compara el actual numero del cliente con el siguiente, si son distintos se procesa el codigo dentro del AT END NOTA: Para sumarizar campos dentro del LOOP a la tabla interna del reporte utilizamos la sentencia ADD o...

Acceder a esta publicación

Creado y Compartido por: Ixhel Magai Lopez Valencia / Disponibilidad Laboral: PartTime + Carta Presentación

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

SAP Senior

1. CORTES DE CONTROL UTILIZANDO TABLAS INTERNAS EN REPORTES Un corte de control es una forma de estructurar un reporte de salida de modo que se puede sumar y mostrar datos totales por los distintos campos del reporte Condición Escencial: Primero deben ordenarse los campos por los cuales se hara el corte de control. Es indispensable, crear una estructura auxiliar para almacenar los datos del registro de la tabla interna del reporte ya que abap completa con (*) los campos que se encuentren a la derecha de los campos donde se hizo el corte y se perderá la información almacenada At new y At end

Acceder a esta publicación

Creado y Compartido por: Javier Mirabal

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

SAP Expert


Cortes de control en tablas internas Son agrupaciones en el procesamiento de las tablas internas, donde es necesario definir el orden para la generación de la salida esperada, para ello podemos utilizar las siguientes sintaxis: AT FIRST/ENDAT - Que realice el primer corte AT LAST/ENDAT - Que realice el corte al final del corte AT NEW/ENDAT - Que realice el corte cada vez que inicie un valor (valor que necesitemos diferenciar) AT END/ENDAT - Que realice el corte al final de un valor (valor que necesitemos diferenciar) al realizar el recorrido se debe asignar a una area de trabajo temporal, para evitar que se reemplace la información con asteriscos o bien utilizando FIELD-SYMBOLS.

Acceder a esta publicación

Creado y Compartido por: Marvin Raul Lopez Morales / Disponibilidad Laboral: FullTime + Carta Presentación

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

SAP Senior

Lección 2/9: Cortes de Control utilizando tablas internas La técnica de corte de control es utilizada cuando se presenta la necesidad de ordenar la tabla interna de salida del reporte, de una determinada manera donde se agrupen los datos a mostrar en la pantalla. Una condición esencial que presentan los cortes de control es que la tabla de salida del reporte debe ordenarse por los campos por los cuales se va a realizar el corte. Es indispensable utilizar una estructura auxiliar para almacenar los datos del registro de la tabla interna del reporte ya que ABAP completará con asteriscos los campos que se encuentren a la derecha del campo por el cual realizamos el corte y se perderá la información almacenada...

Acceder a esta publicación

Creado y Compartido por: Ruben Santiago Cuenca Balanza / Disponibilidad Laboral: FullTime + Carta Presentación

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

SAP Senior

CORTES DE CONTROL UTILIZANDO TABLAS INTERNAS Corte de control: es una forma de estructurar un reporte de salida de modo de poder sumarisar datos y mostrar totales por distintos campos del reporte. Una condicion esencial que presentan los cortes de control es que la tabla de salida del reporte debe ordenarse por los campos por los cuales se va a realizar el corte de control. Es indispensable utilizar una estructura auxiliar para almacenar los datos del registro de la tabla interna del reporte, ya que ABAP completara con asteriscos los campos que se encuentren a la derecha a la derecha del campo por el cual realizamos el corte y se perdera la informacion almacenada en ello. Principalmente vamos a utilizar las sentencias ADD NEW y ADD END. La...

Acceder a esta publicación

Creado y Compartido por: Miguel Ochoa

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

SAP SemiSenior

Resumen Lección: Cortes de control utilizando tablas internas Un corte de control es una forma de estructurar un reporte de salida de modo de poder sumarizar datos y mostrar totales por distintos campos del reporte, una condición esencial que presentan los cortes de control es que la tabla de salida del reporte debe ordenarse por los campos por los cuales se va a realizar el cortes de control. Es indispensable utilizar una estructura auxiliar para almacenar los datos del registro de la tabla interna del reporte, ya que, ABAP completara con astericos los campos que se encuentren a la derecha del campos por el cual realizamos el corte y se perderá la información almacenada en ellos. Principalmente vamos a utilizar las...

Acceder a esta publicación

Creado y Compartido por: Alexander José Tovar Rodríguez

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

SAP Senior

Cortes de control utilizando tablas internas. Los cortes de control es una forma de estructurar un reporte de salida en el que acumular datos de distintos campos. Condición. La tabla de salida debe ordenarse por los campos que se va a realizar el corte de control. Se debe utilizar una estructura auxiliar para almacenar los datos del registro de la tabla interna ya que ABAP completará con asteriscos los campos que se encuentren a la derecha por el cual se esta realizando el corte de control. Sentencias usadas en los cortes de control. AT NEW. esta compara el valor actual del campo con el anterior, si son distintos se procesa el código que se encuentra dentro del AT NEW. AT END. esta compara el valor actual del campo con...

Acceder a esta publicación

Creado y Compartido por: Carlos Rodriguez Escudero / Disponibilidad Laboral: FullTime

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

SAP SemiSenior

Unidad 3. Lección 2: Cortes de Control utilizando tablas internas. Uno corte de control es una forma de estructura, un reporte de salida que sumariza datos y mostrar totales por distintos campos del reporte. Una condición especial que presentan los cortes de control es que la tabla de salida del reporte debe ordenarse por los campos por los cuales se va a realizar el corte de control. Es indispensable utilizar una estructura auxiliar para almacenar los datos del registro de la tabla interna del reporte, ya que ABAP completará con asteriscos los campos que se encuentren a la derecha del campo por el cual realizamos el corte de control y se perderá la información almacenada en ello. Principalmente se emplean...

Acceder a esta publicación

Creado y Compartido por: Kelly Rocio Nino Ramirez

 


 

👌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!