✒️ABAP El procesamiento de los datos
ABAP El procesamiento de los datos
1 | 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.
La segunda forma es mediante la sentencia MOVE.
- MOVE v_cantidad1 TO 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:
- * 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,George',
- 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,
- * Estructura 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 sería el siguiente:
* Declaración de variables
- v_texto = ''.
- v_numero = 0.
- v_texto_largo = ''.
- v_alfabeto= ''.
- wa_usuario-nombre = ''.
- wa_usuario-tel = ''.
- wa_usuario-cod_postal = 0.
- wa_doctor-titulo = ''.
- wa_doctor-nombre = ''.
- wa_doctor-apellido = ''.
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.
- IF v_campo IS INITIAL.
- WRITE 'La variable esta vacia.'.
- ENDIF.
La sentencia IS INITIAL es muy útil cuando se trabaja con tablas internas (concepto que veremos más adelante en el curso).
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 SEPARTED '.'.
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érico que se utilizará como separador entre los campos V_CAMPO1, V_CAMPO2 y V_CAMPO3.
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 de mayúscula a minúscula o viceversa, o para realizar sustituciones de caracteres a través de ciertas reglas.
- TRASLATE 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.
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'.
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.
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.
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.
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.
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.
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.
- SUBTRACT 1 FROM v_numero.
- MULTIPLY v_numero BY 2.
- DIVIDE v_numero BY 2.
Aguarda unos instantes a continuación compartiremos un vídeo en donde analizaremos varios temas muy interesantes relacionados a lo que vimos a lo largo de la lección.
 
 
 
Sobre el autor
Publicación académica de Alex Francisco Lemos Collazos, en su ámbito de estudios para la Carrera Consultor ABAP.
Alex Francisco Lemos Collazos
Profesión: Ingeniero en Sistemas - Colombia - Legajo: QS36A
✒️Autor de: 174 Publicaciones Académicas
🎓Cursando Actualmente: Master S/4HANA Material Management
🎓Egresado de los módulos:
- Máster Material Management en SAP S/4HANA LOGISTIC
- Carrera Consultor ABAP Nivel Avanzado
- Carrera Consultor ABAP Nivel Inicial
- Carrera Consultor en SAP SD Nivel Inicial