Commande LOOP
Exécute une série de commandes ACLScript de manière répétée alors qu'une condition spécifiée est évaluée sur vrai.
Remarque
La commande LOOP doit être insérée à l'intérieur de la commande GROUP.
Syntaxe
LOOP WHILE test commande <...n> END
Paramètres
Nom | Description |
---|---|
WHILE test |
Le test qui doit renvoyer la valeur « vrai » avant l'exécution des commandes dans la commande LOOP. Si le test renvoie « vrai », les commandes sont exécutées à répétition jusqu'à ce que le test renvoie « faux ». |
commande <...n> |
Une ou plusieurs commande à exécuter. Vous pouvez saisir plusieurs commandes au sein de la commande LOOP. Chaque commande doit commencer sur une nouvelle ligne. |
END | Fin de la commande LOOP. |
Exemples
Diviser un champ délimité par des virgules
Une table contient des données de facture et vous avez besoin d'isoler certaines informations pour des montants de facture par service. Une facture peut être reliée à plusieurs services et les codes des services sont enregistrés dans un format séparé par une virgule dans la table.
Pour extraire les montants de facture par service, vous :
- Utilisez une commande GROUP pour traiter la table, enregistrement par enregistrement.
- Calculez le nombre de services (n) associé à chaque enregistrement.
- Utilisez la commande LOOP pour effectuer une itération sur l'enregistrement x fois afin d'extraire les données pour chaque service associé à l'enregistrement.
COMMENT utilisez GROUP pour compter les virgules dans chaque champ de code de département afin d'identifier le nombre de départements associés à l'enregistrement appliquez "LOOP" à chaque enregistrement pour chaque code du champ en extrayant chaque code dans son propre enregistrement END GROUP v_department_count = OCCURS(Department_Code,',') v_counter = 0 LOOP WHILE v_counter <= v_department_count v_dept = SPLIT(Department_Code, ',', (v_counter + 1)) EXTRACT FIELDS Invoice_Number, Invoice_Amount, v_dept AS "Department" TO result1 v_counter = v_counter + 1 END END
Remarques
Astuce
Pour voir le tutoriel détaillé sur les commandes LOOP et GROUP, reportez-vous à la rubrique Regroupement et exécution de boucles.
Quand utiliser LOOP
Des boucles sont souvent utilisées lorsqu'un enregistrement contient des répétitions de segments de données que vous souhaitez traiter.
Fonctionnement
Chaque commande LOOP doit indiquer une condition WHILE à tester, et se terminer par une instruction END. Les commandes situées entre LOOP et END sont exécutées à répétition sur l'enregistrement actuel, tant que le test spécifié renvoie « vrai ».
Si le test renvoie initialement « faux », les commandes ne sont pas exécutées.
Éviter des boucles infinies
Pour éviter de créer une boucle infinie, assurez-vous que le test puisse toujours se révéler faux. Vous pouvez également utiliser la commande SET LOOP pour éviter une boucle infinie.