Expressions Looker
Les expressions Looker (parfois appelées Lexp) permettent d'effectuer des calculs dans les contextes suivants:
Une expression Looker est créée à partir d'une combinaison des éléments suivants:
NULL::la valeur
NULL
indique qu'il n'y a pas de données. Elle peut être utile lorsque vous souhaitez vérifier qu'un élément est vide ou n'existe pas.Constante:valeur que vous fournissez et qui ne change pas. Un nombre tel que
7
ou une chaîne telle queCompleted
sont des constantes.Champ Looker:référence à un champ Looker, qui inclut des dimensions, des mesures et des calculs de table.
Un opérateur Looker:il existe plusieurs types d'opérateurs (qui sont listés sur la page de documentation Fonctions et opérateurs Looker):
- Opérateurs mathématiques (
+
,-
,*
et/
, par exemple) - Opérateurs de comparaison (par exemple,
=
,>
et<=
) - Opérateurs logiques (par exemple,
AND
,OR
etNOT
)
- Opérateurs mathématiques (
Fonction Looker:ces fonctions sont semblables aux fonctions Excel. Les fonctions vous permettent de transformer vos données ou de les référencer de manière complexe. Toutes les fonctions disponibles sont listées sur la page de documentation Fonctions et opérateurs Looker.
Créer des expressions Looker
Les calculs de table, les champs personnalisés et les filtres personnalisés utilisent l'éditeur d'expressions Looker. Lorsque vous saisissez votre expression, Looker vous propose des fonctions, des opérateurs et des noms de champs que vous pouvez utiliser.
Affichage de toutes les suggestions
Pour accéder à l'éditeur d'expressions Looker dans une exploration, créez un calcul de table, un champ personnalisé ou un filtre personnalisé.
Saisissez un espace pour afficher la liste de tous les champs, fonctions et opérateurs disponibles. Si un champ est actuellement sélectionné dans l'exploration, Looker affiche un point noir à gauche du champ et le place en haut de la liste.
Commencez à saisir dans l'éditeur d'expressions Looker pour réduire la liste aux éléments qui vous intéressent.
L'éditeur des champs personnalisés affiche les champs d'exploration actuellement utilisés, s'ils sont compatibles avec la fonction du champ personnalisé.
Ajouter un champ
Pour inclure un champ Looker dans votre expression, commencez à saisir le nom du champ. À mesure que vous saisissez du texte, l'éditeur affine votre recherche à une liste de champs et de fonctions contenant ce que vous avez saisi. Vous pouvez saisir le nom du champ tel qu'il apparaît sur la page "Explorer" ou utiliser son nom LookML si vous le connaissez.
Lorsque vous sélectionnez un champ dans la liste, Looker l'ajoute à votre expression à l'aide du nom LookML au format ${view_name.field_name}
. Cela garantit que tous vos champs ont des noms uniques dans votre expression.
Ajouter des totaux
Si vous créez une expression basée sur une exploration dans laquelle vous avez affiché des totaux, vous pouvez également inclure des totaux de colonne et de ligne dans votre expression. Les totaux des colonnes s'affichent dans l'éditeur, avec le mot Total devant l'itération LookML du nom du champ. Par exemple, pour un champ nommé Nombre, Looker nomme le total de la colonne Count - Total
.
Le nom LookML des totaux se présente sous la forme ${view_name.field_name:total}
, où :total
est ajouté à la fin du nom du champ.
Pour les totaux de ligne, les mots Totals de ligne apparaissent devant le nom du champ dans l'éditeur. Dans le nom LookML du champ, :row_total
est ajouté à la fin du nom du champ, comme ${view_name.field_name:row_total}
.
Ajouter des opérateurs
Si nécessaire, vous pouvez ajouter des opérateurs logiques tels que AND
, OR
et NOT
à votre expression. En règle générale, les opérateurs AND
sont évalués avant les opérateurs OR
, mais vous pouvez ignorer ce comportement à l'aide de parenthèses. Vous pouvez également utiliser des opérateurs de comparaison (par exemple, >
, =
et <=
) et des opérateurs mathématiques (par exemple, +
et *
).
Lorsque vous pointez sur un opérateur, des notes sur son utilisation correcte s'affichent dans le panneau d'informations.
Ajouter des fonctions
Pour inclure une fonction Looker dans votre expression, commencez à saisir son nom. À mesure que vous saisissez du texte, l'éditeur affine votre recherche à une liste de champs et de fonctions contenant ce que vous avez saisi.
Les fonctions peuvent être constituées d'arguments (ou de variables) qui nécessitent un certain type, comme un champ, un nombre ou un oui/non. Lorsque vous pointez sur une fonction, vous pouvez consulter les notes qui s'affichent à côté de votre expression dans le volet d'informations pour savoir quels arguments vous devez fournir et de quel type ils doivent être.
Vous pouvez consulter la liste complète des fonctions proposées par Looker sur la page de documentation Fonctions et opérateurs Looker.
Utiliser les indices d'erreur et le volet d'informations
Looker affiche un volet d'informations à côté de l'éditeur d'expressions Looker. Ce volet fournit de la documentation et des suggestions, en particulier si votre expression contient une erreur.
Le volet d'informations à côté de l'éditeur d'expressions fournit les informations suivantes:
Surlignage des erreurs:Looker souligne en rouge les parties de l'expression qui ne sont pas encore correctes.
Suggestions et détails de l'erreur:Looker vous suggère ce que vous pouvez ajouter ensuite dans votre expression. En cas d'erreur, il explique pourquoi elle se produit. En cas d'erreurs multiples, celle qui s'affiche dépend de l'emplacement du curseur.
Documentation:Looker affiche la documentation sur la fonction ou l'opérateur avec lesquels vous travaillez, en fonction de la position de votre curseur. Par exemple, lorsque vous saisissez le premier argument d'une fonction
if()
, Looker fournit les informations indiquant si le premier argument doit être évalué comme vrai ou faux. Vous pouvez cliquer sur le nom de la fonction pour accéder à sa documentation.
y compris les commentaires
Vous pouvez inclure des commentaires dans les expressions Looker en commençant la ligne de commentaire par #
dans l'éditeur d'expressions.
Utiliser des champs
Vous pouvez parfois utiliser la valeur d'un champ (une dimension, une mesure ou un calcul de tableau) dans une expression. Vous pouvez ajouter la valeur du champ à un autre élément, vérifier qu'elle a une valeur spécifique, l'inclure dans une fonction, etc.
Comme indiqué plus haut sur cette page, vous pouvez saisir le nom du champ dans l'éditeur d'expressions. Looker vous aidera à trouver la bonne façon de le référencer. Lorsque vous ajoutez un champ à une expression, Looker utilise l'identifiant LookML du champ, qui ressemble à ${view_name.field_name}
. Saisissez le nom du champ tel qu'il apparaît dans le sélecteur de champs. L'éditeur d'expressions affichera le nom du sélecteur de champs et l'identifiant LookML ensemble.
Il existe plusieurs façons de récupérer une valeur:
Obtenir une valeur de la même ligne:le moyen le plus simple d'utiliser un champ consiste à le référencer directement. Par exemple, votre expression peut utiliser
${product.category}
. Vous indiquez ainsi que pour chaque ligne, vous devez récupérer la catégorie de produits.Obtenir une valeur d'une autre ligne:vous pouvez également obtenir la valeur d'un champ d'une autre ligne. Par exemple, vous pouvez utiliser la logique suivante : "Pour chaque ligne donnée, récupérez la catégorie de produits de la ligne précédente." Pour ce faire, vous pouvez utiliser une fonction de décalage (consultez cette liste de fonctions de position). La fonction de décalage peut se présenter comme suit:
offset(${product.category}, -1)
.Obtenir une valeur à partir d'une colonne pivotée:vous pouvez également obtenir des valeurs à partir de colonnes pivotées. Par exemple, vous pouvez utiliser la logique "Pour chaque ligne, récupérez le total des ventes de la première colonne pivotée". Pour travailler avec des colonnes pivotées, vous devez utiliser des fonctions pivot (consultez cette liste de fonctions pivot). La fonction pivot peut se présenter comme suit:
pivot_index(${order.total_sales}, 1)
.Obtenir un total à partir d'une ligne ou d'une colonne:si vous avez ajouté des totaux à votre exploration, vous pouvez obtenir les valeurs totales de la colonne ou de la ligne en ajoutant
:total
(pour les totaux de colonne) ou:row_total
(pour les totaux de ligne) au nom du champ, au format${field_name:total}
. Par exemple, si vous souhaitez obtenir un pourcentage du total d'un nombre de Commandes, vous pouvez créer un calcul de tableau comme ceci:${orders.count} / ${orders.count:total}
.
Utiliser des opérateurs
Les expressions Looker peuvent inclure des opérateurs logiques, de comparaison et mathématiques pour créer différentes conditions:
- Opérateurs logiques (par exemple,
AND
,OR
etNOT
) - Opérateurs de comparaison (par exemple,
>
et<
) - Opérateurs mathématiques (
+
et-
, par exemple)
Sauf indication contraire entre parenthèses, la logique AND
est prise en compte avant la logique OR
. L'expression suivante sans parenthèses supplémentaires:
if (
${order_items.days_to_process}>=4 OR
${order_items.shipping_time}>5 AND
${order_facts.is_first_purchase},
"review", "okay")
est évaluée comme suit:
if (
${order_items.days_to_process}>=4 OR
(${order_items.shipping_time}>5 AND ${order_facts.is_first_purchase}),
"review", "okay")
Dans Looker, vous devez utiliser yes
et no
au lieu de true
et false
. Ces constantes logiques ne sont pas identiques aux mots "yes"
et "no"
, qui sont placés entre guillemets. Pour en savoir plus, consultez la description des constantes logiques.
Utiliser des fonctions
Les expressions Looker incluent souvent une ou plusieurs fonctions, qui vous aident à récupérer certaines données ou à calculer certaines choses. Elles sont de nature similaire aux fonctions Excel.
Les fonctions prennent la forme d'un nom suivi de deux parenthèses, comme suit: my_function()
. Vous devrez peut-être fournir des informations entre ces parenthèses, séparées par des virgules. Ces éléments d'information sont appelés "arguments" et se présentent comme suit: my_function(argument_1, argument_2)
.
Par exemple, la fonction now
n'accepte aucun argument et vous indique la date et l'heure actuelles. Vous l'utilisez comme suit: now()
.
La fonction round
accepte un argument, qui est un nombre. Vous l'utilisez comme suit: round(3.2)
. Le résultat est 3
.
Il existe deux façons de savoir quels arguments vous devrez fournir, le cas échéant:
- Le volet d'informations qui s'affiche à côté de l'éditeur d'expressions fournit des informations sur la fonction que vous écrivez. Vous pouvez cliquer sur le nom de la fonction pour accéder à sa documentation.
- Vous pouvez également accéder directement à la page de documentation sur les fonctions et opérateurs Looker et rechercher la fonction que vous souhaitez utiliser.
Prenons l'exemple de la fonction contains
, dont la documentation se présente comme suit:
Fonction | Syntaxe | Objectif |
---|---|---|
contient | contains(string, search_string) |
Renvoie Yes si string contient search_string , et No dans le cas contraire. |
Vous pouvez voir que deux arguments sont obligatoires. Elles portent les noms string
et search_string
, mais cela ne signifie pas que vous devez saisir les mots exacts "chaîne" et "chaîne_de_recherche" dans la fonction. Il ne s'agit que de noms pour les arguments que vous remplacerez par quelque chose. En lisant l'objectif, nous voyons que string
doit être un champ ou une autre valeur dans laquelle nous souhaitons effectuer une recherche, tandis que search_string
est l'élément que nous souhaitons rechercher. Par exemple:
contains(${customer.feedback_text}, "great")
Si le mot "excellent" apparaît dans les commentaires des clients, cette fonction renvoie Yes
. Sinon, le résultat est No
.
Vous pouvez placer des fonctions dans d'autres fonctions pour gérer une logique complexe. Tant que le résultat de la fonction interne est approprié pour les arguments de la fonction externe, tout fonctionnera. Exemple :
contains(
if(
is_null(${customer.feedback_text}),
${customer.comment_text},
${customer.feedback_text}
),
"great")
La fonction is_null
est imbriquée dans une fonction if
, qui se trouve elle-même dans une fonction contains
. Voici comment cela fonctionne:
- La fonction
is_null()
recherche le texte des commentaires des clients. - Ensuite, la fonction
if()
utilise ce résultat et renvoie le texte des commentaires du client, le cas échéant, ou le texte du commentaire du client. - Enfin, la fonction
contains()
utilise le texte renvoyé par la fonctionif()
et recherche le mot "great" (excellent).
Logiquement, cette expression signifie: "Si des commentaires des clients sont disponibles, effectuez une recherche dans ces commentaires. Si ce n'est pas le cas, recherchez plutôt dans les commentaires des clients. Dans les deux cas, recherchez le mot "great".