WORD a STRING
La función WORD_TO_STRING convierte un valor del tipo de datos WORD en un valor del tipo STRING.
Genera un string con el resultado en representación decimal y justificado a la derecha. Se rellena con espacios vacíos hasta alcanzar el número de caracteres definidos en el string.
Entrada
Salida
Cuando se utiliza el tipo de datos STRING con un PLC pequeño como el FP-e o el FP0, asegurarse de que la longitud de la cadena de caracteres destino es igual o superior a la longitud de la cadena fuente.
Entrada |
Salida definida como |
Transformado en |
---|---|---|
16#ABCD |
STRING[1] |
'D' |
STRING[2] |
'CD' |
|
STRING[3] |
'BCD' |
|
STRING[4] |
'ABCD' |
|
STRING[5] |
'0ABCD' |
|
STRING[6] |
'00ABCD' |
|
y así sucesivamente ... |
Todas las variables de entrada y de salida utilizadas para la programación de esta función han sido declaradas en la Cabecera de la POU. Se utiliza la misma cabecera de la POU para todos los lenguajes de programación.
VAR
input_value: WORD:=0;
result_string: STRING;
La variable de entrada input_value del tipo de datos WORD se inicializa a 16#ABCD. La variable de salida result_string es de tipo de STRING[6]. Puede almacenar un máximo de 6 caracteres. En lugar de utilizar la variable input_value, se puede introducir directamente una constante en el contacto de entrada de la función.
El valor de input_value del tipo de datos WORD se convierte a STRING[6]. El resultado de la conversión se almacena en result_string. Si la variable input_value = 16#ABCD, result_string muestra '00ABCD'.
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 2 ;
NETWORK_BODY
B(B_F,WORD_TO_STRING!,Instance,11,0,21,2,,?D?C);
B(B_VARIN,,input_value,9,0,11,2,);
B(B_VAROUT,,result_string,21,0,23,2,);
L(1,0,1,2);
END_NETWORK_BODY
END_NET_WORK
END_BODY
result_string:=WORD_TO_STRING(input_value);
Este ejemplo muestra cómo crear una cadena STRING[4] de tipo WORD en la que se desecha el prefijo '16#'.
Todas las variables de entrada y de salida utilizadas para la programación de esta función han sido declaradas en la Cabecera de la POU. Se utiliza la misma cabecera de la POU para todos los lenguajes de programación.
VAR
input_value: WORD:=16#1234;
(*example value*)
result_string1: STRING[7]:='';
(*result: here '0001234'*)
result_string: STRING[4]:='';
(*result: here '1234'*)
END_VAR
En este ejemplo, se ha declarado tanto la variable de entrada input_value de tipo WORD como la variable de salida result_string de tipo STRING[4].
Para ejecutar la operación en cuestión, se ha conectado la función estándar RIGHT a la función WORD_TO_STRING. RIGHT crea un cadena de caracteres justificados a la derecha de longitud L.
En este ejemplo, la cadena de salida de la función WORD_TO_STRING se introduce en la entrada de la función RIGHT. En la entrada L de RIGHT, el valor constante 4 de tipo INT determina la longitud del STRING a reemplazar. A partir de input_value = 0001234, se obtiene el valor 1234 en result_string como resultado de la función de conversión y de la función estándar RIGHT.
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 2 ;
NETWORK_BODY
B(B_F,WORD_TO_STRING!,Instance,11,0,21,2,,?D?C);
B(B_VARIN,,input_value,9,0,11,2,);
B(B_VAROUT,,result_string1,21,0,23,2,);
L(1,0,1,2);
END_NETWORK_BODY
END_NET_WORK
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 5 ;
NETWORK_BODY
B(B_VARIN,,result_string1,10,2,12,4,);
B(B_VAROUT,,result_string,17,2,19,4,);
B(B_F,RIGHT!,Instance,12,1,17,5,,?DIN?DL?C);
B(B_VARIN,,4,10,3,12,5,);
L(1,0,1,5);
END_NETWORK_BODY
END_NET_WORK
END_BODY