🚀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

Vídeo - Cortes de control utilizando tabla internas

1 Cortes de control utilizando tablas internas en reportes

Vemos a continuación un vídeo donde se exponen los cortes de control para la generación de listados, utilizando las sentencias AT.

Esta forma de trabajo, que a simple vista parece complicada, es muy simple de utilizar y simplifica mucho la tarea del programador en la generación de reportes.

Veremos como realizar un corte de contro la una tabla interna par apoder imprimir un listado por pantalla.

<< copia del código del video >>

Supongamos que tenemos una tabla interna con registros de clientes que incluyen un "importe" entre sus campos, y queremos obtener un listado de clientes donde se muestre en una sola línea el importe total por cada cliente.

En este caso tendremos que realizar un corte de control por cada cliente, y un corte adicional para imprimir los resultados.

Lo primero que hacemos es cargar la tabla interna con distintos registros.

Después ordenamos la tabla interna de clientes según el orden en el que queremos que se visualicen los datos.

Después recorremos la tabla para realizar el listado. Antes de realizar el corte de control dentro del LOOP, pasamos los datos que se están leyendo a una estructura auxiliar (st_clientes_aux). Esto se debe a que ABAP completa con asteriscos todos los campos a la derecha del campo por el cual hacemos el corte.

Para realizar el corte de control por cliente utilizamos la sentencia AT NEW seguida del número del cliente (nrocli). Internamente la sentencia AT NEW compara el actual número de cliente con el anterior. Si estos son distintos, entonces se procesará el código que está entre el AT NEW y ENDAT.

Luego, como queremos imprimir por pantalla el total por cliente, acumulamos el importe.

Para realizar la impresión de los datos utilizamos la sentencia AT END, seguida del campo por el cual hacemos el corte. Internamente la sentencia AT END compara el actual número de cliente con el siguiente número de cliente. Si estos clientes son distintos, entonces se procesará el código que está entre AT END y ENDAT.

Si ejecutamos el programa vemos el listado ordenado por cliente, donde se muestra el total acumulado para cada uno de ellos.

Audio: Vamos a remarcar los conceptos más importantes a tener en cuenta acerca de los cortes de control. Un corte de control es una forma de estructurar un reporte de salida de modo que podemos 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 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 * los campos que se encuentren a la derecha del campo por el cual realizamos el corte, y por tanto se perdería la información almacenada en ellos.

Principalmente vamos a utilizar las sentencias AT NEW y AT END.

La sentencia AT NEW <campo> comparará el valor actual del campo con el valor anterior del campo. En caso de ser distintos, se procesará el código de dentro del AT NEW..ENDAT.

La sentencia AT END <campo> comparará el valor actual del campo con el valor siguiente del campo, es decir el que se encuentra en la próxima vuelta de la tabla interna. En caso de ser distintos, se procesará el código de dentro del AT END..ENDAT.

Para sumar campos dentro del LOOP a la tabla interna del reporte, podemos utilizar la sentencia ADD o también la sentencia SUM que se utiliza para sumarizar variables de tipo integer, P o Flow.

Es posible realizar el corte de control por más de un campo. En este caso, colocaremos en el AT NEW o en del AT END el campo que se encuentre más a la derecha.

Por ejemplo, supongamos que tenemos nuestra tabla interna ti_tabla, con los campos: <campo1> <campo2> y <campo3> en ese orden. Si quisiéremos realizar un corte de control hasta <campo3>, solo colocaríamos AT NEW <campo3> o AT END <campo3>.

Si quisiéramos realizar un corte de control hasta <campo2>, colocaríamos entonces colocaríamos AT NEW <campo2> o AT END <campo2>.

También existen las sentencias AT FIRST y AT LAST, que no se utilizan muy a menudo pero nos pueden ayudar para algún requerimiento muy específico.

Los datos de cada registro de la tabla interna tienen que seguir el orden en el que queremos hacer el corte. Es decir, si tenemos un registro con los campos <c1, c2, c3, c4>, no podremos realizar cortes por los campos <c3> y <c2>, pero sin embargo si podremos realizar cortes por los campos <c1> y <c4>.

Dudas de alumnos:

Quiero hacer un reporte con 2 cortes de control. Es decir, teniendo Clientes, cuentas y montos.

Primeramente hacer un corte por CUENTA, sumando todos los importes de la cuenta, y luego un corte de control por el CLIENTE, sumando todos los importes del cliente.

Como deberíamos hacer esto?

Ej:

Cliente 1

Cuenta 10 300.000

Cuenta 20 450.000

Cuenta 30 500.000

Total Cliente1: 12.500.000

Cliente 2

Cuenta 40 300.000

Cuenta 60 450.000

Cuenta 80 500.000

Total Cliente2: 12.500.000

Cliente 3

Cuenta 140 300.000

Cuenta 640 450.000

Cuenta 820 500.000

Total Cliente3: 12.500.000

Respuesta:

Tendrías que realizar los siguientes pasos:

Supongamos que la tabla interna se llama TI_CLIENTES.

1-Ordenas la tabla interna TI_CLIENTES por CLIENTE y CUENTA.

2-Recorres la tabla interna LOOP AT TI_CLIENTES INTO WA_CLIENTES.

3-Guardas en una estructura auxiliar WA_CLIENTES_AUX el contenido del registro que estas recorriendo y en adelante trabajas con esa estructura auxiliar WA_CLIENTES_AUX.

4-Realizas un AT NEW CLIENTE y dentro cada vez que cambia el CLIENTE borras la variable V_TOTAL_CLIENTE que es donde vamos a sumarizar el total por cliente.

5-Fuera del AT NEW CLIENTE sumamos el total de cliente ADD WA_CLIENTES-MONTOS TO V_TOTAL_CLIENTE.

6-Realizas un AT NEW CUENTA y dentro, cada vez que cambia la CUENTA borras la variable V_TOTAL_CUENTA que es donde vamos a sumarizar el total por cuenta.

7-Fuera del AT NEW CUENTA sumamos el total de la cuenta ADD WA_CLIENTES-MONTOS TO V_TOTAL_CUENTA.

8-Realizas un AT END CUENTA y dentro imprimis el nombre de la cuenta WA_CLIENTES-CUENTA y el total que esta almacenado en V_TOTAL_CUENTA.

9-Realizas un AT END CLIENTE y dentro imprimis el nombre de la cuenta WA_CLIENTES-CLIENTE y el total que esta almacenado en V_TOTAL_CLIENTE.


 

 

 

Agradecimiento:

Ha agradecido este aporte: Steve Romero Quiquia

Favorito:

Está publicación ha sido agregada a sus favoritos por: Lorena Amoretti


Sobre el autor

Publicación académica de José Antonio Saavedra Rodríguez, en su ámbito de estudios para la Carrera Consultor ABAP.

SAP Expert


✒️+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 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 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

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

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

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

 


 

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