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

Unidad n°3: el diccionario de datos
Lección n°2: Los cortes de control usando tablas internas (ti)

Corte de control:

Es la forma de estructurar un reporte de salida por pantalla de modo de poder sumarizar datos y mostrar totales por distintos campos del reporte.
Para hacer estos reportes trabajaremos con ti, para almacenar los registros que obtengamos de las tablas base de datos o cargar manualmente los registros de datos que surjan. Luego vamos a estructurar y formatear los datos que se mostrarán como salida del programa.

Estructurar y formatear será la forma de organizar la salida de los datos en la pantalla, dándoles un formato determinado, agrupando los campos de salida, etc.


Paso a paso para implementar un corte de control:

Para esto, tomaremos como ejemplo el Reporte de Clientes por Región y Distrito:

  1. Declarar la ti "ti_clientes" de salida del reporte. Tendrá una particularidad esta tabla y es que 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 ti será el mismo en el que se desea que esos campos se vean por pantalla. Su wa será "wa_clientes":
    "Tipos de datos:
    TYPES: BEGIN OF ty_clientes,
    region(10) TYPE c,
    distrito(10) TYPE c,
    numcliente(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

  2. Por una particularidad de ABAP, debemos declarar siempre una estructura auxiliar "wa_clientes_aux", a parte de la que ya declaramos al momento declarar la ti:
    DATA: wa_clientes_aux LIKE LINE OF ti_clientes.
  3. Declarar la variable de tipo i para cada importe que deseamos sumarizar, es decir, declararemos las variables:
    DATA: v_importe_total_cliente TYPE i,
    v_importe_total_distrito TYPE i,
    v_importe_total_region TYPE i.
  4. Ahora hay que borrar el contenido de la ti "ti_clientes" con REFRESH, se hace ya que a pesar de que no hayamos llenado los registros, podrían quedar con basura en memoria de ejecuciones anteriores.
  5. Llenaremos la ti cargando cada registro completando los campos; región, distrito, num. cliente e importe:
    REFRESH ti_clientes.

    CLEAR wa_clientes.
    wa_clientes-region = 'CAPITAL'.
    wa_clientes-distrito = 'Caballito'.
    wa_clientes-numcliente = '000001'.
    wa_clientes-importe = 30.
    APPEND wa_clientes TO ti_clientes.

    CLEAR wa_clientes.
    wa_clientes-region = 'CAPITAL'.
    wa_clientes-distrito = 'Caballito'.
    wa_clientes-numcliente = '00700'.
    wa_clientes-importe = 1000.
    APPEND wa_clientes TO ti_clientes.
  6. Ordenar la ti por los campos por los que se hará el corte de control (por región, distrito y num cliente). Recordemos que si usamos la sentencia SORT no especificamos el ordenamiento, por ende se ordenará ascendientemente:
    SORT ti_cliente BY region distrito numcliente.
  7. Recorreremos la ti y es donde el LOOP-ENDLOOP se hará el corte de control. Una vez dentro del LOOP, primero hay que pasar el contenido de la wa "wa_clientes" a "wa_clientes_aux".
  8. Para hacer el corte de control podemos usar:

    Sentencia AT NEW "AT NEW campo. ... ENDAT." Que se ejecuta por cada valor nuevo que se encuentra almacenado en el campo. Esta sentencia compara el contenido del campo del registro actual con el anterior de la ti que se procesó
    Si el resultado de la comparación es que los contenidos son diferentes, se ejecuta la lógica que está dentro del AT NEW.
    Si el resultado es que el contenido de ambos son iguales, no se ejecuta la lógica que está dentro del AT NEW.
    Si estamos procesando el 1er registro de la ti, entonces compara el contenido del campo contra nada y el resultado de esa comparación es que son distintos, por ende se ejecuta la lógica del AT NEW.

    Sentencia AT END OF (AT END OF campo. ... ENDAT.):se ejecuta cuando se está procesando el último registro que tenga almacenado un valor de campo. La sentencia compara el contenido del campo del registro actual de la ti contra el contenido del campo del registro siguiente de la ti que no se procesó.
    Si el resultado de la comparación es que ambos campos son diferentes, se ejecuta la lógica del AT END OF.
    Si el resultado de la comparación es que ambos campos son iguales, no se ejecuta la lógica.
    Si se está procesando el último registro de la ti, entonces compara el contenido del campo contra nada y el resultado de esa comparación es que son distintos por loq ue se ejecuta la lógica.
  9. Por cada nueva región a ejecutar un AT NEW REGION, inicializaremos la variable "v_importe_total_region" que sumariza el importe x región e imprimir la región que es procesada:
    AT NEW region.

    CLEAR v_importe_total_region.
    FORMAT COLOR 1.

    WRITE:/ sy-uline(83).
    WRITE:/ 'Region', wa_clientes_aux-region.
    WRITE:/ sy-uline(83).

    ENDAT.
  10. Para cada nuevo distrito ejecutaremos un AT NEW DISTRITO e inicializaremos la variable "v_importe_total_distrito" (sumariza e importa por distrito e imprime el distrito que estamos procesando).
    AT NEW

    CLEAR v_importe_total_distrito.
    FORMAT COLOR 5.
    WRITE:/10 'Distrito:' wa_clientes_aux-distrito.

    ENDAT.
  11. Por cada nuevo num de cliente ejecutaremos un "AT NEW numcliente" e inicializaremos la variable "v_importe_total_cliente" que sumariza el importe x cliente:
    AT NEW

    CLEAR v_importe_total_cliente.

    ENDAT.
  12. Fuera de los AT NEW hay que sumarizar o acumular cada importe que mostraremos en el reporte:
    ADD wa_clientes_aux-importe TO v_total_cliente.
    ADD wa_clientes_aux-importe TO v_total_distrito.
    ADD wa_clientes_aux-importe TO v_total_region.
  13. Imprimir el total por cliente, usando AT END OF NUMCLIENTE y en caso de ser el último núm. de cliente, se ejecutará la lógica que está dentro del AT END OF (que es imprimir en pantalla el núm de cliente y el importe total acumulado x cliente):
    AT END OF numcliente.

    FORMAT COLOR 3.
    WRITE:/30 'Cliente:', wa_clientes_aux-numcliente.
    50 'Importe total cliente', v_importe_total_cliente.
    ENDAT.
  14. Imprimir el total por distrito, cuando el último registro del distrito se ejecute. Para ello usaremos AT END OF DISTRITO. En caso de ser el último, se ejecutará la lógica que se encuentra dentro del AT END OF (imprimir en pantalla el importe total acumulado por distrito):
    AT END OF distrito.

    FORMAT COLOR 5.
    WRITE:/10 'Importe total distrito:', v_importe_total_cliente.

    ENDAT.
  15. Imprimir el total por región, cuando se ejecute el último registro correspondiente a la región que estamos procesando. Usaremos AT END OF REGION; en caso de ser la última, se ejecutará la lógica que está dentro del AT END OF (imprimir por pantalla el importe total acumulado x region):
    AT END OF region.

    FORMAT COLOR 1.
    WRITE:/ 'Importe total region:', v_importe_total_region.

    ENDAT.

    ENDLOOP.

 

 

 


Sobre el autor

Publicación académica de Candela Estefanía Calzada, en su ámbito de estudios para la Carrera Consultor ABAP.

SAP Expert


Candela Estefanía Calzada

Profesión: Técnica Electrónica - Argentina - Legajo: JW91W

✒️Autor de: 160 Publicaciones Académicas

🎓Egresado de los módulos:

Disponibilidad Laboral: FullTime

Presentación:

Me encuentro estudiando la ingeniería en sistemas de información. poseo amplia experiencia en edición de videos. tengo bases entorno a la programación que quiero continuar consolidando.

Certificación Académica de Candela Calzada

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