|
|
|
|
- Fonctionnement
- Agrégations existantes
<Tableau>.Agrège (Fonction) En anglais : <Array>.Reduce Exécute une opération d'agrégation sur chaque élément d'un tableau WLangage.
tabValeur est un tableau d'entiers = [1,2,3,4,5] LaSomme est un entier LaSomme = tabValeur.Agrège((Valeur, LaSomme) => { RENVOYER Valeur + LaSomme }, 0) // Note : cet exemple est didactique ; pour faire la somme des éléments d'un tableau, // il est préférable d'utiliser la fonction Somme Syntaxe
<Résultat> = <Tableau>.Agrège(<Opération à effectuer> [, <ValeurInitiale>])
<Résultat> : Type correspondant au résultat Résultat de l'opération d'agrégation demandée. <Tableau> : Tableau WLangage Nom de la variable de type Tableau à manipuler. Ce tableau doit être un tableau à une dimension. <Opération à effectuer> : Procédure WLangage Nom de la procédure WLangage à exécuter. Cette procédure peut être : - une procédure globale ou locale,
- une procédure interne.
Il est également possible d'utiliser directement une lambda. <ValeurInitiale> : Paramètre optionnel, type correspondant à la valeur initiale Valeur initiale à utiliser lors de la première exécution de la procédure <Opération à effectuer>. Remarques Fonctionnement La procédure <Opération à effectuer> est appelée une première fois avec deux paramètres : - le premier élément du tableau,
- la valeur initiale spécifiée avec le paramètre <Valeur initiale>.
La procédure est ensuite appelée pour tous les autres éléments du tableau avec deux paramètres : - l'élément du tableau,
- la valeur renvoyée par l'appel précédent.
Exemple didactiqueConsidérons l'exemple suivant : tabValeur est un tableau d'entiers = [1,2,3,4,5] LaSomme est un entier LaSomme = tabValeur.Agrège((Valeur, LaSomme) => { RENVOYER Valeur + LaSomme }, 0) Dans cet exemple, le code : LaSomme = tabValeur.Agrège((Valeur, LaSomme) => { RENVOYER Valeur + LaSomme }, 0) est équivalent au code suivant : LaSomme = tabValeur.Agrège(Additionne, 0) PROCÉDURE INTERNE Additionne(Valeur, Total) RENVOYER Valeur + Total FIN Avec cette procédure interne, il est possible de découper le calcul de la façon suivante : - RésultatIntermédiaire1 = Additionne (t[1], ValeurInitiale) : dans l'exemple Additionne( 1, 0 ) -> 1
- RésultatIntermédiaire2 = Additionne (t[2], RésultatIntermédiaire1) : dans l'exemple Additionne( 2, 1 ) -> 3
- ...
Note : cet exemple est didactique ; pour faire la somme des éléments d'un tableau, il est préférable d'utiliser la fonction <Tableau>.Somme. Agrégations existantes Les agrégations les plus courantes sont disponibles en WLangage :
| | <Tableau>.Moyenne | Calcule la moyenne de plusieurs éléments : - éléments d'un tableau,
- valeurs numériques, ...
| <Tableau>.Somme | Calcule la somme des éléments d'un tableau. |
Enchaînement de fonctionsIl est possible d'enchaîner les différentes fonctions de manipulation d'un tableau. Les fonctions suivantes peuvent être utilisées dans un enchaînement : Cet enchaînement pourra être utilisé comme source d'une instruction POUR TOUT ou se terminer par une des fonctions suivantes : Exemple : gnMoyenne = gtabUser.Filtre(cbFiltre).Transforme(cbTransforme).Moyenne()
Liste des exemples associés :
|
Exemples unitaires (WINDEV) : Les fonctions Filtre / Transforme / Agrège
[ + ] Cet exemple montre l'utilisation des fonctions Filtre / Transforme / Agrège. Le concept de Filter / Map / Reduce (Filtre / Transforme / Agrège en français) permet de réaliser des opérations sur des collections de données de manière extrêmement concise. La fonction Filtre permet de filtrer un tableau d'éléments de manière personnalisée (avec une procédure callback). La fonction Transforme permet de transformer un tableau d'éléments, toujours avec une procédure callback. La fonction Agrège permet d'agréger des données de manière personnalisée avec une procédure callback. Ici, cet exemple permet de calculer l'âge moyen des femmes parmi les utilisateurs affichés dans un champ Table.
|
Classification Métier / UI : Code neutre
Documentation également disponible pour…
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|