Lire en anglais

Partager via


IF

s’applique à :colonne calculéetable calculéeMeasurecalcul visuel

Vérifie une condition, and retourne une value lorsqu’elle est TRUE, sinon elle retourne un secondvalue.

Syntaxe

DAX
IF(<logical_test>, <value_if_true>[, <value_if_false>])

Paramètres

Terme Définition
logical_test Toute expression valueor qui peut être évaluée à TRUEorFALSE.
value_if_true La value retournée if le test logique est TRUE.
value_if_false (Facultatif) La value retournée if le test logique est FALSE. If omis, BLANK est retourné.

Retourner value

Soit value_if_true, value_if_false, orBLANK.

Remarques

  • La fonction IF peut retourner un type de données variant ifvalue_if_trueandvalue_if_false sont de types de données différents, mais la fonction tente de retourner un type de données unique if les deux value_if_trueandvalue_if_false sont des types de données numériques. Dans ce dernier cas, la fonction IFconvert implicitement les types de données pour prendre en charge les deux values.

    Par exemple, la formule IF(<condition>, TRUE(), 0) retourne TRUEor 0, mais la formule IF(<condition>, 1.0, 0) retourne uniquement les valueseven décimales, bien que value_if_false soit du type de données nombre entier. Pour en savoir plus sur la conversion implicite des types de données, consultez types de données.

  • Pour exécuter les expressions de branche indépendamment de l’expression de condition, utilisez IF.EAGER à la place.

Exemples

Les définitions de colonnes calculées Product table suivantes utilisent la fonction IF de différentes manières pour classifier chaque product en fonction de sa liste price.

L’exemple teste si la colonne liste de est inférieure à 500. Lorsque cette condition est true, la valuefaible est retournée. Comme il n’y a pas de value_if_falsevalue, BLANK est retourné.

Vous pouvez utiliser des exemples dans cet article avec le modèle sample Adventure Works DW 2020 Power BI Desktop. Pour obtenir le modèle, consultez DAXsample modèle.

DAX
Price Group =
IF(
    'Product'[List Price] < 500,
    "Low"
)

L’exemple second utilise le même test, mais cette time inclut un value_if_falsevalue. Par conséquent, la formule classifie chaque product comme LoworHigh.

DAX
Price Group =
IF(
    'Product'[List Price] < 500,
    "Low",
    "High"
)

Le troisième exemple utilise le même test, mais cette time imbrication d’une fonction IF pour effectuer un test supplémentaire. Ainsi, la formule classifie chaque product comme Low, Medium, orHigh.

DAX
Price Group =
IF(
    'Product'[List Price] < 500,
    "Low",
    IF(
        'Product'[List Price] < 1500,
        "Medium",
        "High"
    )
)

Conseil

Lorsque vous devez imbriquer plusieurs fonctions IF, la fonction SWITCH peut être une meilleure option. Cette fonction offre un moyen plus élégant d’écrire une expression qui retourne plus de deux valuespossibles.

IF.EAGER fonction
SWITCH fonction (DAX)
fonctions logiques