✒️ABAP El procesamiento de los datos
ABAP El procesamiento de los datos
PROCESAMIENTO DE LOS DATOS
Asignación de valores
Existen dos formas básicas para asignar un valor a una variable. La primera consiste en la asignación simple.
v_cantidad2 = v_cantidad1. "Asigno v_cantidad1 a v_cantidad2
La segunda forma es mediante la sentencia MOVE.
MOVE v_cantidad1 TO v_cantidad2. "Asigno v_cantidad1 a v_cantidad2
Inicialización de Variables
Para la inicialización o borrado del contenido de las variables utilizamos la sentencia CLEAR.
CLEAR <variable>
Si inicializamos las variables que declaramos a continuación:
El contenido de los campos sería el siguiente:
Una sentencia muy importante a la hora de consultar el contenido de las variables que declaramos en nuestros programas es IS INITIAL. En la siguiente imagen vemos un ejemplo de su utilización.
INFO: La sentencia IS INITIAL es muy útil cuando se trabaja con tablas internas. Para más ayuda presionar F1 sobre la sentencia.
Operaciones con caracteres
Existen algunas funciones que se utilizan para tratar caracteres que son muy útiles en el trabajo diario de un programador ABAP. Ellas son:
- CONCATENATE: se utiliza para concatenar varios campos alfanuméricos en uno solo.
CONCATENATE v_campo1 v_campo2 v_campo3 INTO v_campo SEPARATED BY '.' .
Esta sentencia concatena los campos V_CAMPO1, V_CAMPO2 Y V_CAMPO3 en la variable V_CAMPO. Todos estos campos son de tipo caracter. Con la cláusula SEPARATED BY se puede especificar un campo alfanuméricos que se utilizará como separador entre los campos V_CAMPO1, V_CAMPO2 Y V_CAMPO3.
INFO: La sentencia CONCATENATE es muy útil cuando se trabaja con fechas ya que las fechas en SAP son del formato AAAAMMDD y cuando se muestran en un listado se deben convertir a DD.MM.AAAA. Para más ayuda presionar F1 sobre la sentencia.
- TRANSLATE: Se utiliza para convertir caracteres en mayúscula a minúscula o viceversa, o para realizar sustituciones de caracteres a través de ciertas reglas.
TRANSLATE v_texto TO UPPER CASE.
La sentencia anterior convierte a mayúsculas el contenido de la variable V_TEXTO, siendo V_TEXTO de tipo caracter.
INFO: La sentencia TRANSLATE es muy útil para la conversión de texto a mayúscula o minúscula. Para más ayuda presionar F1 sobre la sentencia.
- REPLACE: reemplaza cierta parte de una cadena de caracteres por otra cadena de caracteres o caracter.
REPLACE 'HOLA' WITH 'Casa' INTO v_texto.
La sentencia anterior reemplaza el contenido de la variable V_TEXTO que es 'Hola' por el texto 'Casa'.
INFO: La sentencia REPLACE es muy útil cuando se trabaja con importes. Para más ayuda presionar F1 sobre la sentencia.
- SPLIT: divide a un campo alfanumérico en varios campos por un separador.
SPLIT v_texto_largo AT ',' INTO v_campo1 v_campo2 v_campo3 v_campo4.
La sentencia anterior utiliza el separador ',' para dividir el contenido del campo V_TEXTO_LARGO en las variables V_CAMPO1, V_CAMPO2, V_CAMPO3 y V_CAMPO4 que son de tipo caracter (TYPE c).
Si todos los campos destino son lo suficientemente grandes para almacenar las partes del campo V_TEXTO_LARGO, SY-SUBRC valdrá 0, caso contrario valdrá 4.
INFO: La sentencia SPLIT es muy útil cuando se trabaja con textos largos y es necesario separarlos por algún caracter especial. Para más ayuda presionar F1 sobre la sentencia.
- SHIFT: se utiliza para desplazar el contenido de un campo alfanumérico. Realiza el desplazamiento del contenido de un campo hasta un string dado.
SHIFT v_alfabeto BY 5 places.
La sentencia anterior realiza el desplazamiento del campo V_ALFABETO hasta la quinta posición, quedando el resto de los caracteres que componen a V_ALFABETO en la variable y eliminando los cinco primeros.
INFO: La sentencia SHIFT es muy útil cuando se trabaja con números de documentos o cualquier otro número que haya sido grabado en tablas SAP con ceros a la izquierda. Para más ayuda presionar F1 Sobre la sentencia.
- SEARCH: se utiliza para buscar una cadena de caracteres dentro de un campo alfanumérico.
SEARCH V_ALFABETO FOR 'ABC'.
La sentencia anterior busca en el campo V_ALFABETO la secuencia de caracteres 'ABC'. Como la secuencia existe, devolverá SY-SUBRC igual a 0. Caso contrario, si no existiera, sería distinto igual a 4.
INFO: La sentencia SEARCH es muy útil cuando se trabaja con tablas internas y se busca la ocurrencia de una determinada cadena en un campo de la tabla. Para más ayuda presionar F1 Sobre la sentencia.
- CONDENSE: se utiliza para borrar espacios en blanco en campos alfanuméricos. Borra cualquier secuencia de espacios en blanco, dejando solo uno que exista entre palabras existentes en el campo. Los espacios en blanco por la izquierda también desaparecen.
CONDENSE wa_doctor.
La salida en pantalla de la sentencia anterior sería 'Dr. Rafael Castro'. Con el agregado de la cláusula NO-GAPS al final de la sentencia, se eliminarán todos los espacios en blanco, es decir, que también se eliminan los espacios existentes entre las palabras.
INFO: La sentencia CONDENSE es muy útil en los reportes, cuando se quiere formatear la salida en pantalla de un campo determinado. Para más ayuda presionar F1 Sobre la sentencia.
Si deseamos buscar un string es decir, una cadena de caracteres que puede estar compuesta por palabras, sentencias, mensajes, etc., en uno o más programas ABAP, podemos utilizar el reporte estándar RSRSCAN1. Este reporte nos mostrará en pantalla la cantidad de ocurrencia de la palabra, sentencia, o mensaje.
Operaciones Aritméticas
En ABAP las cuatro operaciones básicas (suma, resta, multiplicación y división) se pueden implementar de dos maneras obteniendo el mismo resultado.
v_campo1 = v_campo2 + v_campo3.
COMPUTE v_campo1 = v_campo2 + v_campo3.
Siendo el resultado el mismo de ambas formas. También se utilizan las siguientes sentencias para operar aritméticamente con datos:
ADD 1 TO v_numero. "Suma 1 a la variable V_NUMERO
SUBTRACT 1 FROM v_numero. "Resta 1 a la variable V_NUMERO
MULTIPLY v_numero BY 2. "Multiplica por 2 a la variable V_NUMERO
DIVIDE v_numero BY 2. "Divide por 2 a la variable V_NUMERO
Se analizará lo visto en la lección.
CO: Contains Only (Contiene Solo)
CN: Contains Not Only (Contiene No Solo)
CA: Contains Any (Contiene Al Menos)
NA: Contains Not Any (No Contiene Al Menos)
CS: Contains String (Contiene Cadena)
NS: Contains No String (No Contiene Cadena)
CP: Covers Pattern (Contiene Patrón)
NP: No Pattern (No Contiene Patrón)
 
 
 
Sobre el autor
Publicación académica de Vismark Eyner Sevillano Moreno, en su ámbito de estudios para la Carrera Consultor ABAP.
Vismark Eyner Sevillano Moreno
Profesión: Tecnologo en Sistemas - Colombia - Legajo: KN43C
✒️Autor de: 62 Publicaciones Académicas
🎓Egresado del módulo:
Disponibilidad Laboral: FullTime
Presentación:
Aprender todo lo relacionado con programación sap abap, para desenvolverme en el área laboral en el sector de programación abap.
Certificación Académica de Vismark Sevillano