Saltar al contenido

Funciones Lógicas

Utilice las funciones lógicas para controlar el flujo de Jitterbit Secuencias de Comandos.

Nota

Se permite un máximo de 50 000 iteraciones de bucle para cada bucle individual en Jitterbit Secuencias de Comandos. Para aumentar el número permitido de iteraciones por bucle, consulte jitterbit.scripting.while.max_iterations en Secuencias de comandos de variables Jitterbit.

Case

Declaración

typeN Case(bool b1, type1 arg1[, bool b2, type2 arg2,... bool bN, typeN argN])

Sintaxis

Case(<b1>, <arg1>[, <b2>, <arg2>,... <bN>, <argN>])

Parámetros Requeridos

  • b1: Una expresión que se evaluará por su resultado booleano
  • arg1: Un argumento que se devolverá si b1 es true

Parámetros Opcionales

  • b2... bN: Expresiones adicionales que se evaluarán para determinar su veracidad
  • arg2... argN: Se devolverán argumentos adicionales si el parámetro coincidente es true

Descripción

Esta función evalúa pares de argumentos: si la evaluación de la expresión en el primer argumento de un par es true, deja de comprobar y devuelve el segundo argumento con el tipo conservado. De lo contrario comprobará el siguiente par y así sucesivamente. Si ninguno de los pares evalúa true, null es regresado.

Para crear un caso predeterminado o alternativo, utilice true y el valor de retorno deseado como último par. Vea el ejemplo.

Ejemplos

Este ejemplo regresa "Very Expensive" si price es 1000 o mas alto. El true en el último par de argumentos sirve como caso predeterminado o alternativo.

$label = Case(price < 10, "Cheap",
              price < 100, "Not Cheap",
              price < 1000, "Expensive",
              true, "Very Expensive");

Equal

Declaración

bool Equal(type1 array1, type2 array2)

bool Equal(type1 arg1, type2 arg2)

Sintaxis

Equal(<array1>, <array2>)

Equal(<arg1>, <arg2>)

Parámetros Requeridos

  • array1, array2: (Primera forma) Dos matrices de la misma longitud y dimensión; si no, la función regresa false

  • arg1, arg2: (Segunda forma) Dos tipos o expresiones simples

Descripción

Realiza una comparación recursiva de dos matrices. Devoluciones true si todos los miembros correspondientes de las matrices son iguales; de lo contrario, devuelve false. También se puede utilizar con tipos simples y sigue reglas de conversión para promover diferentes tipos y compararlos.

Llamar a esta función para comparar dos matrices es diferente a usar la función == operador en dos matrices. Utilizando el == el operador en dos matrices devuelve una matriz de valores booleanos que contiene el resultado de una comparación de cada miembro de la matriz. El uso de esta función compara cada elemento correspondiente por turno.

El Equal() La función siempre devuelve falso si los dos argumentos de la matriz tienen tamaños diferentes.

La conversión y promoción de tipos se realiza si los argumentos o elementos que se comparan son de diferentes tipos.

Ejemplos

x = {1, 2.0, 3};
y = {1, 5, 3};

// Returns false since 2.0 != 5
Equal(x, y);

// Returns true because both arrays contain only non-zero numbers.
// Comparison is made as booleans
Equal(Bool(x), y);

If

Declaración

typeN If(bool condition, type1 trueResult[, type2 falseResult])

Sintaxis

If(<condition>, <trueResult>[, <falseResult>])

Parámetros Requeridos

  • condition: Una expresión que se evaluará por su resultado booleano
  • trueResult: Una expresión que se evaluará y su resultado se devolverá si condition es true

Parámetros Opcionales

  • falseResult: Una expresión que se evaluará y su resultado se devolverá si condition es false

Descripción

Devoluciones trueResult si la condición es verdadera, de lo contrario regresa falseResult.

Si el primer argumento (condition) no es un tipo de datos booleano, se convierte a booleano antes de evaluarse. Si no se especifica el tercer argumento opcional y condition es false, a null se devuelve el valor.

Ejemplos

//  Returns "Diane"
If(false, "Jack", "Diane");

// Returns "Spoon"
If(7>4, "Spoon", "Knife");

// Adds a trailing comma to s if s is not empty
If(Length(s)>0,
    s = s + ",";
    );

While

Declaración

null While(bool condition, type expression)

Sintaxis

While(<condition>, <expression>)

Parámetros Requeridos

  • condition: Una expresión que se evaluará por su resultado booleano
  • expression: Una expresión que se evaluará repetidamente siempre que condition es true

Descripción

Ejecuta repetidamente una expresión siempre que una condición sea verdadera.

La variable Jitterbit jitterbit.scripting.while.max_iterations limita el número de iteraciones. Se informa un error si se alcanza el número máximo de iteraciones.

Ejemplos

$jitterbit.scripting.while.max_iterations = 2000;
i = 0;
arr = {"a@example.com", "b@example.com", "c@example.com"};
s = "";
// Concatenates the elements of the array arr
// with commas separating each element
While(i < Length(arr),
    s = s + Get(arr,i) + ",";
    i++;
    );