✒️ABAP El procesamiento de los datos
ABAP El procesamiento de los datos
PROCESAMIENTO DE LOS DATOS
· La primera consiste en la asignación simple. Ejemplo.:
· La segunda forma es mediante la sentencia MOVE.
MOVE v_cantidad1 TO v_cantidad2. “asigno v_cantidad1 a v_cantidad2
INICIALIZACION DE VARIABLES
Para la inicialización o borrado del contenido de las variables utilizamos la sentencia CLEAR.
Si inicializamos las variables que declaramos a continuación:
* Declaración de variables
DATA: v_texto (4) TYPE c VALUE ‘Hola’,
v_numero TYPE i VALUE 12345,
v_texto_largo (30) TYPE c VALUE ‘John, Paul,Ringo,Georgr’,
v_alfabeto (10) TYPE c VALUE ‘ABCDEFGHIJ’,
* Estructura para usuarios
BEGIN OF wa_usuario,
nombre (15) TYPE c VALUE ‘Ricardo’,
tel (8) TYPE n VALUE ‘49818567’,
cod_postal TYPE p VALUE 1405,
END OF wa_usuario,
* Estructrura para doctores
BEGIN OF wa_doctor,
titulo (10) TYPE c VALUE ‘Dr, ’,
nombre (10) TYPE c VALUE ‘Rafael ’,
apellido (10) TYPE c VALUE ‘Castro’
END OF wa_doctor.
El contenido de los campos serial el siguiente:
v_texto = ‘ ’.
v_numero = 0.
v_texto = ‘ ’.
v_texto_largo = ‘ ’.
wa_usuario-nombre = ‘ ’.
wa_usuario-tel = 00000000.
wa_usuario-cod_postal = 00000000.
wa_doctor-titulo = ‘ ’.
wa_doctor-nombre = ‘ ’.
wa_doctor-nombre = ‘ ’.
Una sentencia muy importante a la hora de consultar el contenido de las variables que declaramos en nuestros programas es IS INITIAL. Ejemplo:
IF v_campo IS INITIAL.
WRITE ‘La variable esta vacia’.
ENDIF.
La sentencia IS INITIAL es muy útil cuando se trabaja con tablas internas.
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 ‘.’.
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.
TRANSLATE: Se utiliza para convertir caracteres de mayúscula a minúscula o viceversa, o para realizar sustituciones de caracteres de ciertas reglas.
TRANSLATE v_texto TO UPPER CASE.
La sentencia anterior convierte a mayúscula el contenido de la variable V_TEXTO, siendo V_TEXTO de tipo carácter.
La sentencia TRANSLATE es muy útil para la conversión de texto a mayúscula o minúscula.
REPLACE: reemplaza cierta parte de una cadena de caracteres por otra cadena de caracteres o carácter.
REPLACE ‘Hola’ WITH ‘casa’ INTO v_texto.
La sentencia anterior reemplaza en contenido de la variable V_TEXTO que es ‘Hola’ por el texto ‘Casa’.
La sentencia REPLACE es muy útil cuando se trabaja con importes.
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 carácter (TYPE c).
Si todos los campos destino son lo suficientemente grandes para almacenar la parte del campo V_TEXTO_LARGO, SY-SUBRC valdrá 0, caso contrario valdrá 4.
La sentencia SPLIT es muy útil cuando se trabaja con textos largos y es necesario separarlos por algún carácter especial.
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 quita posición, quedando el resto de los caracteres que componen a V_ALFABETO en la variable y eliminando los cinco primeros.
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.
SEARCH: se utiliza para buscar una cadena de caracteres dentro de un campo alfanumérico.
SEARCH V_ALFABETO FOR ‘ABC’
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.
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 seria ‘Dr. Rafael Castro’. Con el agregado de la cláusula NO-GAPS al final de la sentencia, se eliminaran todos los espacios en blanco, es decir que también se eliminaran los espacios entre las palabras.
La sentencia CONDENSE es muy útil en los reportes, cuando se quiere formatear la salida en pantalla de un campo determinado.
OPERADORES ARISMETICOS
En aba 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 en ambas formas. También se utilizan las siguientes sentencias para operaciones aritméticas con datos:
ADD 1 TO v_numero. “suma 1 a la variable V_NUEMRO
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
 
 
 
Sobre el autor
Publicación académica de Jean Carlos Lopez Uzcategui, en su ámbito de estudios para la Carrera Consultor ABAP.
Jean Carlos Lopez Uzcategui
Profesión: Sistemas - Venezuela - Legajo: HS82J
✒️Autor de: 53 Publicaciones Académicas
🎓Egresado del módulo:
Disponibilidad Laboral: FullTime
Certificación Académica de Jean Lopez