Instructions en boucle
Les informations sur cette page d’aide concernent à la fois CXone Studio et Desktop Studio.
Les instructions en boucle vous permettent de configurer le script pour qu’il réalise une tâche ou un ensemble de tâches de manière répétée jusqu'à ce que la condition de fin spécifiée soit remplie. Cette fonctionnalité est utile si vous voulez effectuer une série de tâches sur chaque membre d'un ensemble.
Les mots clés des instructions en boucle sont les suivants :
- FOR : exécute les instructions intégrées tant qu'une expression booléenne Un type de données qui a deux valeurs possibles : true et false. est évaluée à vrai.
- FOREACH : exécute les instructions intégrées une fois pour chaque élément d'un tableau.
- REPEAT : exécute les instructions intégrées un nombre de fois spécifié.
Les instructions en boucle exigent toujours des blocs de code conditionnels. Les blocs sont entourés d'accolades (
BREAK : termine un ensemble d'instructions en boucle.
Instructions FOR
Description : répète une instruction ou une série d'instructions un nombre précis de fois.
Syntaxe : FOR <var> = <start> TO <end> <{ ... [BREAK] }>
Détails : une boucle FOR répète le code entre accolades {...} une fois pour chaque valeur de nombre entier comprise entre <start> et <end>. Les clauses <start> et <end> peuvent être des expressions ou des valeurs littérales. À chaque itération, la valeur actuelle de la plage est affectée à une variable <var> nommée dans la ligne d'en-tête de la boucle. C'est ce qu'on appelle la variable d’itérateur.
La clause facultative BREAK interrompt la boucle. Le script continue ensuite, en exécutant le code après l'accolade fermante ou en passant à l'action Exécute un processus dans un script Studio, tel que la collecte de données client, la lecture d'un message ou d'une musique, ou l'acheminement d'un contact vers un agent. Studio suivante.
La valeur initiale de <start> et <end> sera évaluée une fois, au début de la boucle. Vous pouvez modifier la valeur de <end> dans les instructions de code entre accolades {...}. Vous pouvez également modifier la valeur de <var> à l'intérieur de la boucle.
La valeur de <start> ne doit pas nécessairement être inférieure à celle de <end>. Si <end> est plus petit que <start>, la boucle se déplace vers le bas. La boucle effectue toujours au moins une itération. Ce comportement est différent de celui de certains autres langages de programmation. Les exemples suivants illustrent ce comportement.
Dans cet exemple, <end> est plus grand que <start>. Le résultat est ph="123456789".
FOR i=1 TO 9
{
ph = "{ph}{i}"
}
Dans cet exemple, <start> est plus grand que <end>. Le résultat est ph="987654321".
FOR i=9 TO 1
{
ph = "{ph}{i}"
}
Exemples
IF TEST = 1
{
ASSIGN Names = "Wes|Nate|Dan|Clay"
ASSIGN EyeColors = "Blue|Blue|Brown|Brown"
ASSIGN Signs = "Aquarius|Aries|Pisces|Leo"
ASSIGN Foods = "Spagetti|Pizza|Sushi|Deep Fried Twinkies"
}
DYNAMIC Persons
ASSIGN PeopleCount = Names.size
FOR i = 1 TO PeopleCount
{
ASSIGN Persons[i].Name = "{Names[i]}"
ASSIGN Persons[i].Eyecolor = "{EyeColors[i]}"
ASSIGN Persons[i].Sign = "{Signs[i]}"
ASSIGN Persons[i].Food = "{Foods[i]}"
}
FOR i=1 TO 9
{
a = "{a}{i}"
}
//Result: a="123456789"
FOR i=9 TO 1
{
b = "{b}{i}"
}
//Result: b="987654321"
Instructions FOREACH
Description : répète une boucle une fois pour chaque élément du tableau de chaînes spécifié.
Format : FOREACH <var> IN <array> <{ ... [ BREAK ] }>
Détails : une boucle FOREACH répète le code entre accolades {...} une fois pour chaque élément d'un tableau de chaînes ou d'un tableau d’objets de données dynamiques. La valeur de chaque élément du tableau est affectée à une variable <var> nommée dans la ligne d'en-tête de la boucle.
La clause facultative BREAK interrompt la boucle. Le script continue ensuite, en exécutant le code après l'accolade fermante ou en passant à l'action Exécute un processus dans un script Studio, tel que la collecte de données client, la lecture d'un message ou d'une musique, ou l'acheminement d'un contact vers un agent. Studio suivante.
L'exemple suivant montre une boucle FOREACH qui comprend une instruction IF.
IF TEST = 1
{
ASSIGN Names="Odin|Freya|Thor|Loki"
}
ASSIGN SubCounter=1
FOREACH Name IN Names
{
IF Name = "Odin" | Name = "Freya"
{
ASSIGN NewNames[SubCounter]= "{Name}"
ASSIGN SubCounter=SubCounter + 1
}
}
Instructions REPEAT
Description : exécute les commandes désignées un nombre de fois spécifié.
Syntaxe : REPEAT <expression> <{ ... [ BREAK ]}>
Détails : cette commande répète le code contenu dans les accolades {...} un nombre de fois défini par <expression>. <expression> peut être n'importe quel entier positif littéral ou une expression évaluée à zéro ou à un entier positif.
Incluez le mot-clé facultatif
Propriétés de l’arborescence
Dans l'onglet Arborescence,
Il comprend les propriétés suivantes à configurer :
- Comment : ajouter un commentaire à propos de la répétition.
- Line Number : le numéro de ligne sur laquelle se trouve la commande dans l'éditeur.
-
Repeat : entrez une expression qui s'évalue en valeur numérique pour définir le nombre de fois que vous voulez que les comportements spécifiés se répètent.
Pour compléter
Exemple
Pour voir cet exemple dans l’arborescence, faites un copier-coller dans l'onglet Vue Texte, puis cliquez sur l'onglet Arborescence.
REPEAT 10
{
phone = "{phone}{random(10)}"
}
Instructions BREAK
Description : termine immédiatement une boucle.
Syntaxe : BREAK
Détails : lorsque l'instruction BREAK est atteinte, la boucle en cours se termine immédiatement. Le script continue d'exécuter le code snippet situé sous la boucle jusqu'à ce qu'il soit terminé.
BREAK est facultatif. S’il n'est pas inclus, la boucle continue jusqu'à ce que la condition d'arrêt définie soit remplie.