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

Control Breaks - Internal Tables

Definition of Control Break:

A control break is a technique used to structure a screen output report in order to summarize data and display totals for different fields in the report.

Implementation Steps for a Control Break:

Control breaks are a technique composed of several steps for correct functionality. Taking the example of the "Customer Report by Region and District"

  • The initial step is to declare the internal output table for the report.


TYPES: BEGIN OF ty_customer,
region(10) TYPE c,
district(10) TYPE c,
customer_no(5) TYPE c,
amount TYPE i,
END OF ty_customer.

DATA: it_customers TYPE STANDARD TABLE OF ty_customer,
wa_customer LIKE LINE OF it_customers.


  • Declaration of Auxiliary Structure: Due to an ABAP specificity, an auxiliary structure, named wa_customers_aux, needs to be declared.

DATA: wa_customer_aux LIKE LINE OF it_customers.


  • Declaration of Summation Variables: Variables of type I are declared for each amount to be summarized.

DATA: v_total_amount_customers TYPE i,
v_total_amount_district TYPE i,
v_total_amount_region TYPE i.

  • Table Initialization and Population: As a programming best practice, the internal table is cleared to ensure no content errors. After this, the table is filled with content.

REFRESH it_customers.
CLEAR it_customers.

wa_customer-region = 'CAPITAL'.
wa_customer-district = 'Caballito'.
wa_customer-customer_no = '00001'.
wa_customer-amount = 30.

APPEND wa_customer TO it_customers.

  • Sorting the Internal Table: The internal table it_customers needs to be sorted based on the fields used for the control break: REGION, DISTRICT, and CUSTOMER_NO.

SORT it_customers BY region district customer_no.

  • Control Break Technique Implementation: Within a LOOP-ENDLOOP construct, the core of the control break technique is executed. It involves copying the content of the wa_customers structure to wa_customers_aux.

LOOP AT it_customers INTO wa_customer.
CLEAR wa_customer_aux.
wa_customer_aux = wa_customer.

ENDLOOP.


  • AT NEW and AT END OF Statements: ABAP provides two statements, AT NEW and AT END OF, for control breaks. AT NEW is executed for each new value in the field, while AT END OF is executed when processing the last record with a specific field value.
AT NEW district.
CLEAR v_total_amount_district.
FORMAT COLOR 5.
WRITE:/ sy-uline(83).
WRITE:/ 'District:', wa_customer_aux-district.
WRITE:/ sy-uline(83).
ENDAT.

AT END OF district.
FORMAT COLOR 5.
WRITE:/10 'Total Amount District', v_total_amount_district.
ENDAT.

  • Total Calculation and Printing: For each new region, district, and customer number, AT NEW statements are executed to initialize corresponding total variables. Then, the accumulated totals are printed.

AT END OF district.
FORMAT COLOR 5.
WRITE:/10 'Total Amount District', v_total_amount_district.
ENDAT.

Summary:

Control breaks involve declaring structures, initializing variables, populating tables, implementing sorting, and utilizing AT NEW and AT END OF statements for effective control break implementation in ABAP.

E.g

* Structure type for customers
TYPES: BEGIN OF ty_customers,
region(10) TYPE c,
district(10) TYPE c,
customer_no(5) TYPE c,
amount TYPE i,
END OF ty_customers.

* Internal tables and structures
DATA: it_customers TYPE STANDARD TABLE OF ty_customers,
wa_customers LIKE LINE OF it_customers,
wa_customers_aux LIKE LINE OF it_customers.

* Accumulation flag
DATA: v_total_amount_accumulated TYPE i.

*----------------------------------------------------------------------*
START-OF-SELECTION.
*----------------------------------------------------------------------*

*----------------------------------------------------------------------*
* Adding records to the internal table
*----------------------------------------------------------------------*
CLEAR wa_customers.
wa_customers-region = 'CAPITAL'.
wa_customers-district = 'Caballito'.
wa_customers-customer_no = '00001'.
wa_customers-amount = 30.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'CAPITAL'.
wa_customers-district = 'Caballito'.
wa_customers-customer_no = '00700'.
wa_customers-amount = 1000.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'CAPITAL'.
wa_customers-district = 'Caballito'.
wa_customers-customer_no = '00705'.
wa_customers-amount = 10000.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'CAPITAL'.
wa_customers-district = 'Flores'.
wa_customers-customer_no = '00005'.
wa_customers-amount = 90.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'CAPITAL'.
wa_customers-district = 'Flores'.
wa_customers-customer_no = '00122'.
wa_customers-amount = 900.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'CAPITAL'.
wa_customers-district = 'Palermo'.
wa_customers-customer_no = '00011'.
wa_customers-amount = 120.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'CAPITAL'.
wa_customers-district = 'Palermo'.
wa_customers-customer_no = '00111'.
wa_customers-amount = 1200.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'CAPITAL'.
wa_customers-district = 'Belgrano'.
wa_customers-customer_no = '00012'.
wa_customers-amount = 20.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'CAPITAL'.
wa_customers-district = 'Belgrano'.
wa_customers-customer_no = '05512'.
wa_customers-amount = 2000.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'CAPITAL'.
wa_customers-district = 'Caballito'.
wa_customers-customer_no = '00001'.
wa_customers-amount = 70.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'AVELLANEDA'.
wa_customers-district = 'Sur'.
wa_customers-customer_no = '00022'.
wa_customers-amount = 30.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'AVELLANEDA'.
wa_customers-district = 'Sur'.
wa_customers-customer_no = '00100'.
wa_customers-amount = 3000.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'AVELLANEDA'.
wa_customers-district = 'Sur'.
wa_customers-customer_no = '00099'.
wa_customers-amount = 6000.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'AVELLANEDA'.
wa_customers-district = 'Norte'.
wa_customers-customer_no = '00029'.
wa_customers-amount = 190.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'AVELLANEDA'.
wa_customers-district = 'Norte'.
wa_customers-customer_no = '00029'.
wa_customers-amount = 190.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'AVELLANEDA'.
wa_customers-district = 'Norte'.
wa_customers-customer_no = '00301'.
wa_customers-amount = 500.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'QUILMES'.
wa_customers-district = 'Centro'.
wa_customers-customer_no = '00084'.
wa_customers-amount = 300.
APPEND wa_customers TO it_customers.

CLEAR wa_customers.
wa_customers-region = 'QUILMES'.
wa_customers-district = 'Ezpeleta'.
wa_customers-customer_no = '00172'.
wa_customers-amount = 50.
APPEND wa_customers TO it_customers.

*----------------------------------------------------------------------*
* Sorting the internal table
*----------------------------------------------------------------------*
SORT it_customers BY region district customer_no.

*----------------------------------------------------------------------*
* Looping through the internal table
*----------------------------------------------------------------------*
LOOP AT it_customers INTO wa_customers.

* Copying the content of the record to an auxiliary structure
CLEAR wa_customers_aux.
wa_customers_aux = wa_customers.

*----------------------------------------------------------------------*
* For each new customer
*----------------------------------------------------------------------*
AT NEW region.
CLEAR v_total_amount_accumulated.
FORMAT COLOR 1.
WRITE:/ sy-uline(55).
WRITE:/ 'Region:', wa_customers_aux-region.
WRITE:/ sy-uline(55).
ENDAT.

AT NEW district.
FORMAT COLOR 5.
WRITE:/ 'District:', wa_customers_aux-district.
ENDAT.

AT NEW customer_no.
CLEAR v_total_amount_accumulated.
ENDAT.

* Accumulating the amount
ADD wa_customers_aux-amount TO v_total_amount_accumulated.

*----------------------------------------------------------------------*
* Printing detail titles
*----------------------------------------------------------------------*
AT END OF customer_no.
FORMAT COLOR 3.
WRITE:/10 'Customer:', wa_customers_aux-customer_no,
30 'Total Amount', v_total_amount_accumulated.
ENDAT.
ENDLOOP.

WRITE:/ sy-uline(55).


 

 

 


Sobre el autor

Publicación académica de Jaime Eduardo Gomez Arango, en su ámbito de estudios para la Carrera Consultor ABAP.

SAP Expert


Jaime Eduardo Gomez Arango

Profesión: Ingeniero de Sistemas y Computación - España - Legajo: SW34C

✒️Autor de: 149 Publicaciones Académicas

🎓Egresado de los módulos:

Disponibilidad Laboral: FullTime

Presentación:

Ingeniero de sistemas y computación con 8 años de experiencia el desarrollo frontend & backend (react/node) y en cloud (aws), actualmente desarrollando habilidades en sap btp, ui5, abap y fiori.

Certificación Académica de Jaime Gomez

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