Excel DAX - Guide rapide

DAX signifie Dà Aanalyse Expressions. DAX est un langage de formule et est une collection de fonctions, d'opérateurs et de constantes qui peuvent être utilisées dans une formule ou une expression pour calculer et renvoyer une ou plusieurs valeurs. DAX est le langage de formule associé au modèle de données d'Excel Power Pivot.

Ce n'est pas un langage de programmation, mais un langage de formule qui permet aux utilisateurs de définir des calculs personnalisés dans des colonnes calculées et des champs calculés (également appelés mesures). DAX vous aide à créer de nouvelles informations à partir des données déjà présentes dans votre modèle de données. Les formules DAX vous permettent de modéliser les données, d'analyser les données et d'utiliser les résultats pour le reporting et la prise de décision.

DAX inclut certaines des fonctions utilisées dans les formules Excel, mais avec des fonctionnalités modifiées et des fonctions supplémentaires conçues pour fonctionner avec des données relationnelles et effectuer une agrégation dynamique.

Importance de DAX

La base de DAX est le modèle de données qui est la base de données Power Pivot dans Excel. Le modèle de données se compose de tables entre lesquelles des relations peuvent être définies afin de combiner les données provenant de différentes sources. Les connexions de données au modèle de données peuvent être actualisées au fur et à mesure que les données source changent. Data Model utilise le moteur d'analyse en mémoire Power Pivot xVelocity (VertiPaq) qui rend les opérations de données aussi rapides que possible en plus de contenir plusieurs milliers de lignes de données. Pour plus d'informations sur le modèle de données, reportez-vous au didacticiel - Power Pivot.

DAX en conjonction avec Data Model permet plusieurs fonctionnalités avancées dans Excel - Power Pivot, Power PivotTables, Power PivotCharts et Power View. Vous pouvez utiliser DAX pour résoudre un certain nombre de calculs de base et de problèmes d'analyse de données.

DAX est également utile dans Power BI pour créer un nouveau fichier Power BI Desktop et y importer des données. En outre, les formules DAX fournissent des fonctionnalités telles que l'analyse du pourcentage de croissance entre les catégories de produits et pour différentes plages de dates, le calcul de la croissance d'une année à l'autre par rapport aux tendances du marché et bien d'autres.

Apprendre à créer des formules DAX efficaces vous aidera à tirer le meilleur parti de vos données. Lorsque vous obtenez les informations dont vous avez besoin, vous pouvez commencer à résoudre de vrais problèmes commerciaux qui affectent vos résultats. C'est la puissance de Power BI et DAX vous aidera à y parvenir.

Prérequis pour ce didacticiel

Ce didacticiel est une extension du didacticiel Excel Power Pivot, dans lequel vous avez découvert la fonction Power Pivot, le modèle de données, les relations, les tableaux croisés dynamiques Power, les graphiques Power Pivot, etc. dans DAX car ce didacticiel porte davantage sur le langage DAX dans lequel vous écrivez des formules pour l'analyse des données dans le modèle de données et rapportez ces résultats.

Ce didacticiel présente également les fonctions DAX qui sont similaires aux fonctions Excel, mais avec quelques variantes. Une comparaison des fonctions Excel et des fonctions DAX est fournie pour vous aider à distinguer les deux. De même, les formules Excel et les formules DAX sont comparées et les similitudes et les différences sont discutées. Une bonne compréhension de ces différences vous aiderait à écrire efficacement des formules DAX efficaces.

La connaissance des fonctions Excel et des formules Excel n'est pas nécessaire pour ce didacticiel, car DAX est entièrement destiné au modèle de données dans la fenêtre Power Pivot. Vous accéderez à une feuille de calcul Excel uniquement pour afficher les tableaux croisés dynamiques Power, les graphiques Power Pivot et les visualisations Power View basées sur le modèle de données. Cependant, si vous êtes un professionnel d'Excel avec une bonne connaissance des fonctions et des formules Excel, mieux vaut noter ce qui est mentionné dans la section précédente et les détails donnés au cours de ce tutoriel.

Colonnes calculées

Les colonnes calculées sont les colonnes que vous pouvez ajouter à une table dans le modèle de données, au moyen d'une formule DAX. Vous les avez déjà appris dans le didacticiel Excel Power Pivot, mais vous apprendrez en détail dans le chapitre - Les colonnes calculées car DAX concerne les colonnes calculées, les champs calculés et les fonctions DAX.

Champs / mesures calculés

Vous ne pouvez pas modifier les valeurs des tables du modèle de données en les modifiant. Toutefois, vous pouvez ajouter des champs calculés à une table qui peut être utilisée dans les Power PivotTables. Les champs calculés sont définis en donnant un nom et en définissant une formule DAX. Pour plus de détails, reportez-vous au chapitre - Champs calculés .

Les champs calculés ont été nommés en tant que mesures dans les versions d'Excel antérieures à Excel 2013. Ils sont renommés en mesures dans Excel 2016. Dans ce didacticiel, nous les référencerons en tant que champs calculés. Mais, notez que les termes - champs calculés et mesures - sont synonymes et désignent les mêmes dans tous les aspects.

Vous pouvez modifier un champ calculé après sa définition et son stockage. Vous pouvez modifier la formule DAX utilisée dans la définition ou renommer le champ calculé. Vous en apprendrez plus à ce sujet dans le chapitre - Modifier un champ calculé . Vous pouvez supprimer un champ calculé. Reportez-vous au chapitre - Suppression d'un champ calculé .

Formules DAX

Les formules DAX forment le cœur du langage DAX. Vous pouvez créer des champs calculés et des colonnes calculées en les définissant avec des formules DAX. Vous pouvez écrire des formules DAX pour les opérations d'analyse de données. Les formules DAX ne font pas référence aux cellules individuelles ou à la plage de cellules du tableau, mais font référence aux tables et aux colonnes du modèle de données. Une colonne dans une table du modèle de données doit contenir le même type de données.

Les formules DAX contiennent les tables, les colonnes, les colonnes calculées, les champs calculés, les opérateurs DAX et les fonctions DAX. Reportez-vous au chapitre - Formules DAX pour en savoir plus.

Syntaxe DAX

Comme c'est le cas avec n'importe quel langage, DAX, le langage de formule a également une syntaxe. Vos formules DAX doivent suivre la syntaxe DAX, sinon vous obtiendrez des erreurs au moment de la conception ou au moment de l'exécution ou vous recevrez des résultats incorrects.

Vous apprendrez ce qui suit dans le chapitre - Syntaxe DAX -

  • Exigences de dénomination DAX pour les tables, les colonnes
  • Opérateurs DAX
  • Valeurs spéciales DAX
  • Types de données DAX
  • Conversions de type de données implicites DAX

Opérateurs DAX

DAX est un langage de formule et utilise donc les opérateurs pour définir les formules. DAX a les types d'opérateurs suivants -

  • Opérateurs arithmétiques DAX
  • Opérateurs de comparaison DAX
  • Opérateur de concaténation de texte DAX
  • Opérateurs logiques DAX

L'ordre de priorité des opérateurs DAX est également défini et varie de l'ordre de priorité des opérateurs Excel. Reportez-vous au chapitre - Opérateurs DAX .

Paramètres standard DAX

La syntaxe de la fonction DAX a certaines exigences sur les paramètres. Cela est dû au fait que les arguments de la fonction DAX peuvent être des tables ou des colonnes ou des champs calculés ou d'autres fonctions DAX. Reportez-vous au chapitre - Paramètres standard DAX .

Fonctions DAX

Excel 2013 dispose de 246 fonctions DAX que vous pouvez utiliser dans les formules DAX. Vous découvrirez ces fonctions au niveau des catégories dans le chapitre -DAX Functions. Cependant, pour plus de détails sur la syntaxe, les paramètres, l'utilisation et les valeurs de retour de chaque fonction DAX, vous devez vous référer à notre tutoriel sur les fonctions DAX . Les noms de section utilisés pour la description de chaque fonction DAX sont donnés dans le chapitre - Comprendre les fonctions DAX .

Comme les fonctions DAX sont requises pour écrire les formules DAX et que les résultats des fonctions DAX utilisées dépendent du contexte dans lequel elles sont utilisées, vous devrez peut-être faire des allers-retours entre ces deux didacticiels pour comprendre DAX que vous utiliserez dans Data Modélisation avec DAX et Power BI.

Fonctions spéciales DAX

DAX a certaines fonctions qui rendent DAX puissant. Ces fonctions DAX relèvent des catégories - fonctions DAX time intelligence et fonctions de filtre DAX et nécessitent une mention spéciale. Vous découvrirez les fonctions de DAX Time Intelligence dans le chapitre - Comprendre DAX Time Intelligence . Vous en apprendrez davantage sur l'utilisation des fonctions de filtre DAX dans le chapitre - Fonctions de filtre DAX .

Contexte d'évaluation DAX

Les résultats d'une formule DAX peuvent varier en fonction du contexte utilisé pour l'évaluation. DAX a deux types de contexte d'évaluation: le contexte de ligne et le contexte de filtre. Reportez-vous au chapitre - Contexte d'évaluation DAX .

Formules DAX

DAX est un langage de formule et vous devez en tirer le meilleur parti en écrivant les formules DAX. Reportez-vous au chapitre - Formules DAX pour en savoir plus sur la syntaxe des formules et comment les créer facilement et correctement.

Les résultats des formules DAX changent chaque fois que les données sont actualisées et chaque fois que les formules DAX sont recalculées. Vous devez comprendre la différence entre l'actualisation et le recalcul des données. Reportez-vous au chapitre - Mise à jour des résultats des formules DAX .

Les données du modèle de données sont attendues et sujettes à des changements de temps à autre. En effet, les données sont utilisées pour des activités d'analyse de données qui nécessitent des données à jour à tout moment. Pour comprendre les différentes manières d'actualiser les données, reportez-vous au chapitre - Mise à jour des données dans le modèle de données .

Vous comprendrez les différents types de recalcul de formule DAX dans le chapitre - Recalculer les formules DAX .

Les recalculs de formules DAX doivent prendre en compte les dépendances de données et suivre un ordre spécifique. Sinon, vous risquez d'obtenir des erreurs ou des résultats erronés. Reportez-vous au chapitre - Dépannage du recalcul de formule DAX pour plus de détails.

Vous aurez un aperçu de certaines des erreurs de formule DAX courantes et vous apprendrez à corriger ces erreurs, dans le chapitre - Erreurs de formule DAX .

Scénarios DAX

Si vous commencez à apprendre une nouvelle langue, la meilleure façon de vous familiariser avec la langue est de comprendre où utiliser quoi. De même, DAX étant un langage de formule destiné à l'analyse des données, vous devez comprendre les différents scénarios dans lesquels il peut être utilisé.

Reportez-vous aux chapitres suivants pour obtenir des détails à ce sujet.

  • Scénarios DAX
  • Scénarios - Exécution de calculs complexes
  • Scénarios - Utilisation du texte et des dates
  • Scénarios - Valeurs conditionnelles et test des erreurs
  • Scénarios - Utilisation de Time Intelligence
  • Scénarios - Classement et comparaison des valeurs

UNE calculated columnest une colonne que vous ajoutez à une table existante dans le modèle de données de votre classeur au moyen d'une formule DAX qui définit les valeurs de colonne. Au lieu d'importer les valeurs dans la colonne, vous créez la colonne calculée.

Vous pouvez utiliser la colonne calculée dans un rapport de tableau croisé dynamique, graphique croisé dynamique, tableau croisé dynamique Power, Power PivotChart ou Power View comme n'importe quelle autre colonne de tableau.

Comprendre les colonnes calculées

La formule DAX utilisée pour créer une colonne calculée est comme une formule Excel. Toutefois, dans la formule DAX, vous ne pouvez pas créer des formules différentes pour différentes lignes d'une table. La formule DAX est automatiquement appliquée à la colonne entière.

Par exemple, vous pouvez créer une colonne calculée pour extraire l'année de la colonne existante - Date, avec la formule DAX -

= YEAR ([Date])

YEAR est une fonction DAX et Date est une colonne existante dans la table. Comme on le voit, le nom de la table est entre crochets. Vous en apprendrez plus à ce sujet dans le chapitre - Syntaxe DAX .

Lorsque vous ajoutez une colonne à une table avec cette formule DAX, les valeurs de colonne sont calculées dès que vous créez la formule. Une nouvelle colonne avec l'en-tête CalculatedColumn1 rempli de valeurs Year sera créée.

Les valeurs de colonne sont recalculées si nécessaire, par exemple lorsque les données sous-jacentes sont actualisées. Vous pouvez créer des colonnes calculées basées sur des colonnes existantes, des champs calculés (mesures) et d'autres colonnes calculées.

Création d'une colonne calculée

Considérez le modèle de données avec les résultats des Jeux olympiques comme indiqué dans la capture d'écran suivante.

  • Cliquez sur la vue des données.
  • Cliquez sur l'onglet Résultats.

Vous verrez le tableau des résultats.

Comme le montre la capture d'écran ci-dessus, la colonne la plus à droite a l'en-tête - Ajouter une colonne.

  • Cliquez sur l'onglet Conception sur le ruban.
  • Cliquez sur Ajouter dans le groupe Colonnes.

Le pointeur apparaîtra dans la barre de formule. Cela signifie que vous ajoutez une colonne avec une formule DAX.

  • Tapez = YEAR ([Date]) dans la barre de formule.

Comme on peut le voir dans la capture d'écran ci-dessus, la colonne la plus à droite avec l'en-tête - Ajouter une colonne est mise en évidence.

  • Appuyez sur Entrée.

Il faudra un certain temps (quelques secondes) pour que les calculs soient effectués. S'il vous plaît, attendez.

La nouvelle colonne calculée sera insérée à gauche de la colonne Ajouter une colonne la plus à droite.

Comme le montre la capture d'écran ci-dessus, la colonne calculée nouvellement insérée est mise en surbrillance. Les valeurs de la colonne entière apparaissent selon la formule DAX utilisée. L'en-tête de colonne est CalculatedColumn1.

Renommer la colonne calculée

Pour renommer la colonne calculée en un nom significatif, procédez comme suit:

  • Double-cliquez sur l'en-tête de la colonne. Le nom de la colonne sera mis en évidence.
  • Sélectionnez le nom de la colonne.
  • Tapez Year (le nouveau nom).

Comme le montre la capture d'écran ci-dessus, le nom de la colonne calculée a été modifié.

Vous pouvez également renommer une colonne calculée en cliquant avec le bouton droit sur la colonne puis en cliquant sur Renommer dans la liste déroulante.

Assurez-vous simplement que le nouveau nom n'est pas en conflit avec un nom existant dans la table.

Vérification du type de données de la colonne calculée

Vous pouvez vérifier le type de données de la colonne calculée comme suit -

  • Cliquez sur l'onglet Accueil sur le ruban.
  • Cliquez sur le type de données.

Comme vous pouvez le voir dans la capture d'écran ci-dessus, la liste déroulante contient les types de données possibles pour les colonnes. Dans cet exemple, le type de données par défaut (Auto), c'est-à-dire le nombre entier, est sélectionné.

Erreurs dans les colonnes calculées

Des erreurs peuvent survenir dans les colonnes calculées pour les raisons suivantes -

  • Modification ou suppression des relations entre les tables. Cela est dû au fait que les formules qui utilisent des colonnes dans ces tables deviendront invalides.

  • La formule contient une dépendance circulaire ou auto-référencée.

Les problèmes de performance

Comme vu précédemment dans l'exemple des résultats des Jeux olympiques, le tableau des résultats contient environ 35 000 lignes de données. Par conséquent, lorsque vous avez créé une colonne avec une formule DAX, il a calculé toutes les 35000+ valeurs de la colonne à la fois, ce qui a pris un peu de temps. Le modèle de données et les tables sont destinés à gérer des millions de lignes de données. Par conséquent, cela peut affecter les performances lorsque la formule DAX a trop de références. Vous pouvez éviter les problèmes de performances en procédant comme suit -

  • Si votre formule DAX contient de nombreuses dépendances complexes, créez-la par étapes en enregistrant les résultats dans de nouvelles colonnes calculées, au lieu de créer une seule grande formule à la fois. Cela vous permet de valider les résultats et d'évaluer les performances.

  • Les colonnes calculées doivent être recalculées lorsque des modifications de données se produisent. Vous pouvez régler le mode de recalcul sur manuel, évitant ainsi les recalculs fréquents. Toutefois, si des valeurs de la colonne calculée sont incorrectes, la colonne sera grisée jusqu'à ce que vous actualisiez et recalculiez les données.

UNE calculated fielddans une table dans un modèle de données est le champ obtenu par une formule DAX. Dans les versions antérieures de Power Pivot, le champ calculé était appelé mesure. Dans Excel 2013, il a été renommé en tant que champ calculé. Cependant, il est renommé pour mesurer dans Excel 2016. Si vous vous référez à une documentation, vous pouvez observer un mélange de ces deux termes. Notez que les termes champ calculé et mesure sont synonymes. Dans ce tutoriel, nous utilisons le terme champ calculé.

Comprendre les champs calculés

Un champ calculé est une formule créée spécifiquement pour une utilisation dans un tableau croisé dynamique (ou un graphique croisé dynamique).

Vous pouvez créer un champ calculé basé sur des fonctions d'agrégation standard, telles que COUNT ou SUM, ou en définissant votre propre formule DAX.

Voici la différence entre le champ calculé et la colonne calculée -

  • Un champ calculé ne peut être utilisé que dans la zone VALEURS d'un tableau croisé dynamique.

  • Une colonne calculée avec les résultats calculés peut également être utilisée dans les zones ROWS, COLUMNS et FILTERS.

Enregistrement du champ calculé

Le champ calculé sera enregistré avec sa table source dans le modèle de données. Il apparaît dans la liste des champs de tableau croisé dynamique ou Power PivotChart en tant que champ dans le tableau.

Utilisation d'un champ calculé

Pour utiliser un champ calculé, vous devez le sélectionner dans la liste Champs de tableau croisé dynamique Power. Le champ calculé sera ajouté à la zone VALUES et la formule utilisée pour le champ calculé sera évaluée. Un résultat est créé pour chaque combinaison de champs de ligne et de colonne.

Champ calculé - Un exemple

Considérez le modèle de données suivant pour les données olympiques -

Comme le montre la capture d'écran ci-dessus, le tableau des résultats a un champ Médaille qui contient les valeurs - Or, Argent ou Bronze pour chacune des lignes contenant la combinaison Sport - Événement - Pays - Date. Supposons que vous souhaitiez un nombre de médailles pour chaque pays, vous pouvez alors créer un champ calculé Nombre de médailles avec la formule DAX suivante -

Medal Count := COUNTA([Medal])

Création d'un champ calculé dans une table

Pour créer le champ calculé Nombre de médailles dans le tableau Résultats, procédez comme suit:

  • Cliquez sur la cellule dans la zone de calcul sous la colonne Médaille dans le tableau Résultats. La cellule sera mise en évidence.

  • Tapez Medal Count: = COUNTA ([Medal]) dans la barre de formule.

Appuyez sur Entrée.

Comme le montre la capture d'écran ci-dessus, le champ calculé apparaît dans la cellule sélectionnée, affichant la valeur 34 094. Ce nombre correspond au nombre total de lignes dans le tableau Résultats. Par conséquent, cela n'a pas beaucoup de sens au premier regard. Comme indiqué précédemment, l'utilisation réelle d'un champ calculé peut être vue uniquement en l'ajoutant à un tableau croisé dynamique ou à un graphique croisé dynamique.

Utilisation du champ calculé dans un tableau croisé dynamique

Pour utiliser le champ calculé pour compter le nombre de médailles pour chaque pays, procédez comme suit:

  • Cliquez sur le tableau croisé dynamique sur le ruban dans la fenêtre Power Pivot.
  • Cliquez sur le tableau croisé dynamique dans la liste déroulante.

La boîte de dialogue Créer un tableau croisé dynamique s'affiche.

  • Cliquez sur la feuille de calcul existante.
  • Sélectionnez l'emplacement où vous souhaitez placer le tableau croisé dynamique.

Un tableau croisé dynamique vide sera créé.

  • Cliquez sur le tableau Résultats dans la liste Champs de tableau croisé dynamique.
  • Cliquez sur les champs - Pays et nombre de médailles.

Comme vous pouvez le constater, le nombre de médailles est ajouté à la zone VALUES et le pays est ajouté à la zone ROWS. Le tableau croisé dynamique est créé avec les valeurs de pays de champ apparaissant dans les lignes. Et pour chaque ligne, la valeur du nombre de médailles est calculée et affichée. C'est ainsi que le champ calculé évalue la formule DAX utilisée et affiche les valeurs.

  • Ajoutez le champ Sport du tableau des résultats à la zone ROWS.

Comme vous pouvez le voir dans la capture d'écran ci-dessus, le décompte des médailles est calculé pour chaque pays - par sport et un sous-total pour le pays lui-même.

C'est ainsi que DAX complète les fonctionnalités Power.

Types de champs calculés

Il existe deux types de champs calculés: implicites et explicites.

  • Un implicit calculated field est créé dans le volet de liste Champs de tableau croisé dynamique Power.

  • Un explicit calculated field est créé dans le tableau de la fenêtre Power Pivot ou à partir du ruban PowerPivot dans la fenêtre Excel.

Création d'un champ calculé implicite

Un champ calculé implicite peut être créé de deux manières, dans le volet Champs de tableau croisé dynamique Power.

Création d'un champ calculé implicite dans la liste des champs de tableau croisé dynamique

Vous pouvez créer le champ Nombre de médailles à partir du champ Médaille dans la liste Champs de tableau croisé dynamique comme suit -

  • Désélectionnez le champ Nombre de médailles.
  • Faites un clic droit sur le champ Médaille.
  • Cliquez sur Ajouter aux valeurs dans la liste déroulante.

Le nombre de médailles apparaît dans la zone Valeurs. La colonne Nombre de médailles sera ajoutée au tableau croisé dynamique.

Création d'un champ calculé implicite dans la zone VALUES

Vous pouvez créer un champ calculé implicite -% de la ligne parent dans la zone Valeurs pour exprimer le nombre de médailles de chaque sport qu'un pays a gagné en pourcentage du nombre total de médailles remportées par ce pays.

  • Cliquez sur la flèche vers le bas dans la zone Nombre de médailles dans la zone VALEURS.
  • Cliquez sur les paramètres du champ de valeur dans la liste déroulante.

La boîte de dialogue Paramètres du champ de valeur s'affiche.

  • Tapez% médailles dans la zone Nom personnalisé.
  • Cliquez sur l'onglet Afficher les valeurs sous.
  • Cliquez sur la case sous Afficher les valeurs sous.
  • Cliquez sur le% du total de la ligne parent.
  • Cliquez sur le bouton Format des nombres.

La boîte de dialogue Format des cellules s'affiche.

  • Cliquez sur Pourcentage.
  • Tapez 0 entre décimales.
  • Cliquez sur OK.
  • Cliquez sur OK dans la boîte de dialogue Paramètres du champ de valeur.
  • Sélectionnez Ne pas afficher les sous-totaux.

Vous avez créé un autre champ calculé implicite% Médailles et comme vous pouvez le constater, pour chaque pays, le pourcentage de médailles par sport est affiché.

Inconvénients d'un champ calculé implicite

Les champs calculés implicites sont faciles à créer. En fait, vous les avez créés même dans les tableaux croisés dynamiques et les graphiques croisés dynamiques Excel. Mais, ils présentent les inconvénients suivants -

  • They are volatile. Cela signifie que si vous désélectionnez le champ que vous avez utilisé pour le champ calculé, il sera supprimé. Si vous souhaitez l'afficher à nouveau, vous devez le créer à nouveau.

  • Their scope is limitedau tableau croisé dynamique ou au graphique croisé dynamique dans lequel ils sont créés. Si vous créez un autre tableau croisé dynamique dans une autre feuille de calcul, vous devez créer à nouveau le champ calculé.

D'autre part, les champs calculés explicites seront enregistrés avec la table et seront disponibles chaque fois que vous sélectionnez cette table.

Création d'un champ calculé explicite

Vous pouvez créer un champ calculé explicite de deux manières -

  • Dans la zone de calcul dans un tableau du modèle de données. Vous l'avez déjà appris dans la section - Création d'un champ calculé dans une table.

  • À partir du ruban PowerPivot dans le tableau Excel. Vous apprendrez cette façon de créer un champ calculé explicite dans la section suivante.

Création d'un champ calculé explicite à partir du ruban PowerPivot

Pour créer un champ calculé explicite à partir du ruban PowerPivot, procédez comme suit:

  • Cliquez sur l'onglet POWERPIVOT sur le ruban dans votre classeur.
  • Cliquez sur les champs calculés dans la zone Calculs.
  • Cliquez sur le nouveau champ calculé dans la liste déroulante.

La boîte de dialogue Champ calculé s'affiche.

  • Remplissez les informations requises comme indiqué dans la capture d'écran suivante.
  • Cliquez sur le bouton Vérifier la formule.
  • Cliquez sur OK uniquement s'il n'y a aucune erreur dans la formule.

Comme vous pouvez le constater, vous pouvez définir la catégorie et le format du champ calculé dans cette boîte de dialogue. En outre, vous pouvez utiliser la fonctionnalité IntelliSense pour comprendre l'utilisation des fonctions et utiliser la fonctionnalité de saisie semi-automatique pour compléter facilement les noms des fonctions, des tables et des colonnes. Pour plus de détails sur la fonctionnalité IntelliSense, reportez-vous au chapitre - Formules DAX .

Il s'agit d'une méthode recommandée pour créer des champs calculés explicites.

Vous pouvez éditer un champ calculé pour le modifier. Mais, avant de modifier un champ calculé, vous devez savoir où il est stocké. Cela signifie, dans quelle table le champ calculé est stocké. Cela vaut pour les champs calculés implicites et explicites. Un champ calculé ne peut être associé qu'à une seule table dans un modèle de données.

Recherche de champs calculés

Pour rechercher les champs calculés dans le modèle de données, procédez comme suit:

  • Cliquez sur l'onglet Avancé du ruban dans la fenêtre Power Pivot.
  • Cliquez sur Afficher les champs calculés implicites.
  • Cliquez sur la vue Diagramme.

Comme vous pouvez le voir dans la capture d'écran ci-dessus, Afficher les champs calculés implicites est mis en évidence sur le ruban. S'il n'est pas mis en surbrillance, cliquez à nouveau dessus.

Vous pouvez également observer qu'il existe 4 cases à cocher - Colonnes, champs calculés, hiérarchies et KPI. Par défaut, tous les 4 sont sélectionnés.

  • Décochez les cases - Colonnes, hiérarchies et indicateurs de performance clés.

Cela ne laissera que la case Champs calculés cochée.

Comme le montre la capture d'écran ci-dessus, seul le tableau Résultats a des champs affichés. Les deux autres tableaux sont vides. Cela montre que seule la table Résultats contient des champs calculés. Vous pouvez également observer que les champs calculés implicites ont une icône

affichée, alors que le champ calculé explicite - Nombre de médailles n'a pas cette icône.

Affichage des champs calculés dans le tableau

Vous pouvez afficher les champs calculés dans le tableau comme suit -

  • Cliquez sur le champ calculé.
  • Cliquez avec le bouton droit de la souris et sélectionnez Atteindre dans la liste déroulante.

Le tableau apparaîtra dans la vue des données.

Comme le montre la capture d'écran ci-dessus, les champs calculés apparaissent dans la zone de calcul de la table.

Modification d'un champ calculé dans le tableau

Vous pouvez modifier la formule utilisée pour un champ calculé dans le tableau.

  • Cliquez sur le champ calculé dans le tableau dans la vue des données du modèle de données.
  • Sélectionnez la formule dans la barre de formule - à droite de: =.

La formule sera mise en évidence.

  • Tapez la nouvelle formule.
  • Appuyez sur Entrée.

Vous en apprendrez plus sur les formules DAX dans les chapitres suivants.

Renommer un champ calculé dans le modèle de données

Vous pouvez modifier le nom d'un champ calculé dans la table de données dans la vue de données ou la vue de diagramme.

Renommer un champ calculé dans la vue des données

  • Cliquez sur le champ calculé dans le tableau dans la vue des données du modèle de données.
  • Sélectionnez le nom du champ calculé dans la barre de formule - à gauche de: =.

Le nom du champ calculé sera mis en évidence.

  • Saisissez le nouveau nom du champ calculé.
  • Appuyez sur Entrée.

Vous en apprendrez plus sur la syntaxe DAX dans les chapitres suivants.

Renommer un champ calculé dans la vue Diagramme

  • Cliquez avec le bouton droit sur le nom du champ calculé dans la table dans la vue de diagramme.
  • Cliquez sur Renommer dans la liste déroulante.

Le nom passera en mode d'édition. Saisissez le nouveau nom du champ calculé.

Affichage des champs calculés dans la fenêtre Excel

Vous pouvez afficher les champs calculés dans la fenêtre Excel comme suit -

  • Cliquez sur l'onglet POWERPIVOT sur le ruban.
  • Cliquez sur Champs calculés dans le groupe Calculs.
  • Cliquez sur Gérer les champs calculés dans la liste déroulante.

La boîte de dialogue Gérer les champs calculés s'affiche. Les noms des champs calculés explicites dans le modèle de données apparaissent dans la boîte de dialogue.

Modification d'un champ calculé dans Gérer les champs calculés

Vous pouvez modifier un champ calculé dans la boîte de dialogue Gérer les champs calculés.

  • Cliquez sur le nombre de médailles.
  • Cliquez sur le bouton Modifier.

La boîte de dialogue Champ calculé s'affiche.

  • Sélectionnez la formule à droite de = dans la zone de formule.
  • Tapez la nouvelle formule.
  • Cliquez sur OK.
  • Cliquez sur Fermer dans la boîte de dialogue Gérer les champs calculés.

Renommer un champ calculé dans Gérer les champs calculés

Vous pouvez renommer un champ calculé dans la boîte de dialogue Gérer les champs calculés.

  • Cliquez sur le nombre de médailles.
  • Cliquez sur le bouton Modifier.

La boîte de dialogue Champ calculé s'affiche.

  • Sélectionnez le nom dans la zone de nom de champ calculé.
  • Saisissez le nouveau nom du champ calculé.
  • Cliquez sur OK.
  • Cliquez sur Fermer dans la boîte de dialogue Gérer les champs calculés.

Déplacement d'un champ calculé dans le modèle de données

Vous pouvez déplacer un champ calculé dans la zone de calcul de la table dans laquelle il est créé. Mais, il ne peut pas être déplacé vers une autre table.

  • Cliquez avec le bouton droit sur le champ calculé.
  • Cliquez sur Couper.
  • Déplacez le pointeur vers un autre emplacement dans la zone de calcul de la même table.
  • Cliquez sur Coller.

Note - L'emplacement du champ calculé dans la zone de calcul de la table n'a pas vraiment d'importance, car les références de données dans la formule DAX du champ calculé sont par les noms de colonne et sont indiquées explicitement.

Vous pouvez supprimer les champs calculés explicites et implicites. Il existe plusieurs façons de le faire, que vous apprendrez dans ce chapitre.

Cependant, vous devez vous rappeler les points suivants avant de supprimer un champ calculé -

  • Un champ calculé explicite peut être utilisé dans plusieurs tableaux croisés dynamiques et / ou graphiques croisés dynamiques. Par conséquent, vous devez vous assurer que la suppression du champ calculé explicite n'affecte aucun des rapports que vous avez déjà générés.

  • Un champ calculé explicite peut être utilisé dans les calculs d'autres champs calculés explicites. Par conséquent, vous devez vous assurer que le champ calculé explicite n'est utilisé dans aucun des calculs d'autres champs calculés explicites.

  • Un champ calculé implicite est limité au tableau croisé dynamique ou au graphique croisé dynamique où il est utilisé. Par conséquent, avant de supprimer un champ calculé implicite, il suffit de s'assurer qu'il peut être supprimé du tableau croisé dynamique ou du graphique croisé dynamique correspondant.

  • La création d'un champ calculé implicite est plus simple que la création d'un champ calculé explicite. Par conséquent, plus de prudence est requise avant de supprimer un champ calculé explicite.

  • Vous ne pouvez pas créer un champ calculé explicite si le nom entre en conflit avec le nom d'un champ calculé implicite. Par conséquent, vous devrez peut-être supprimer ce champ calculé implicite avant de créer le champ calculé explicite.

Suppression d'un champ calculé explicite dans le modèle de données

Vous pouvez supprimer un champ calculé explicite dans la vue de données ou dans la vue de diagramme dans le modèle de données.

Suppression d'un champ calculé explicite dans la vue de données

  • Recherchez le champ calculé dans la zone de calculs de la vue des données.
  • Cliquez avec le bouton droit sur le champ calculé.
  • Cliquez sur Supprimer dans la liste déroulante.

Un message apparaît pour la confirmation de la suppression.

Cliquez sur Supprimer du modèle. Le champ calculé explicite sera supprimé.

Suppression d'un champ calculé explicite dans la vue Diagramme

  • Localisez le champ calculé dans la table de données de la vue Diagramme.
  • Cliquez avec le bouton droit sur le nom du champ calculé.
  • Cliquez sur Supprimer dans la liste déroulante.

Un message apparaît pour la confirmation de la suppression.

Cliquez sur Supprimer du modèle. Le champ calculé explicite sera supprimé et n'apparaîtra pas dans la liste des champs de la table de données.

Suppression d'un champ calculé explicite dans la fenêtre Excel

Vous pouvez supprimer un champ calculé explicite de la fenêtre Excel comme suit -

  • Cliquez sur l'onglet POWERPIVOT sur le ruban.
  • Cliquez sur Champ calculé dans le groupe Calculs.
  • Cliquez sur Gérer les champs calculés dans la liste déroulante.

La boîte de dialogue Gérer les champs calculés s'affiche.

  • Cliquez sur le nom du champ calculé explicite.
  • Cliquez sur le bouton Supprimer.

Un message de confirmation de suppression apparaît.

  • Cliquez sur Oui. Un message d'information indiquant que le modèle de données a été modifié apparaît en haut.
  • Cliquez sur le bouton Fermer dans la boîte de dialogue.

Le champ calculé explicite sera supprimé et il ne sera pas vu dans la liste des champs de tableau croisé dynamique / graphique croisé dynamique dans le classeur.

Suppression d'un champ calculé implicite

Vous pouvez supprimer un champ calculé implicite dans la vue de données ou dans la vue de diagramme dans le modèle de données.

Suppression d'un champ calculé implicite dans la vue de données

  • Recherchez le champ calculé dans la zone de calculs de la vue des données.
  • Cliquez avec le bouton droit sur le champ calculé.
  • Cliquez sur Supprimer dans la liste déroulante.

Un message apparaît pour la confirmation de la suppression.

  • Cliquez sur Supprimer du modèle. Le champ calculé implicite sera supprimé.

Suppression d'un champ calculé implicite dans la vue Diagramme

  • Localisez le champ calculé dans la table de données de la vue Diagramme.
  • Cliquez avec le bouton droit sur le nom du champ calculé.
  • Cliquez sur Supprimer dans la liste déroulante.

Un message apparaît pour la confirmation de la suppression.

Cliquez sur Supprimer du modèle. Le champ calculé implicite sera supprimé et n'apparaîtra pas dans la liste des champs de la table de données.

Comme indiqué précédemment, DAX est un langage de formule comprenant des opérateurs, des valeurs, des fonctions et des formules. Dans ce chapitre, vous découvrirez la syntaxe DAX.

DAX Syntax peut être classé comme -

  • Syntaxe des formules DAX
  • Exigences de dénomination DAX
  • Valeurs spéciales DAX
  • Fonctions DAX
  • Opérateurs DAX
  • Types de données DAX

Avant de commencer à apprendre la syntaxe DAX, vous devez comprendre la différence entre les formules Excel et les formules DAX.

Différences entre les formules Excel et les formules DAX

Les formules DAX sont similaires aux formules Excel et vous pouvez les saisir dans la barre de formule. Cependant, il existe des différences essentielles entre les deux.

Formule Excel Formule DAX

Les formules Excel sont saisies dans la barre de formule de la fenêtre Excel.

Les formules DAX sont tapées dans la barre de formule de la fenêtre Power Pivot.

Dans les formules Excel, vous pouvez référencer des cellules ou des tableaux individuels pour les données.

Dans les formules DAX, vous ne pouvez référencer que des tables ou des colonnes de données complètes, c'est-à-dire que les références ne peuvent concerner que les tables et les champs des tables.

Cependant, si vous devez effectuer un calcul uniquement sur une partie des données de la colonne, vous pouvez le faire avec les fonctions DAX qui filtrent et fournissent les valeurs de données uniques requises pour le calcul.

Les formules Excel prennent en charge certains types de données.

DAX fournit plus de types de données qu'Excel. Par conséquent, les formules DAX peuvent également utiliser les types de données supplémentaires.

Excel ne prend en charge aucune conversion de données implicite.

DAX effectue des conversions de type de données implicites pendant les calculs.

DAX est un langage de formule comprenant des fonctions, des opérateurs et des valeurs qui peuvent être utilisés dans une formule ou une expression, pour calculer et renvoyer une ou plusieurs valeurs.

Vous pouvez utiliser DAX operatorspour comparer des valeurs, effectuer des calculs arithmétiques et concaténer des chaînes. Dans ce chapitre, vous découvrirez les opérateurs DAX et comment les utiliser.

Types d'opérateurs DAX

DAX prend en charge les types d'opérateurs suivants -

  • Opérateurs arithmétiques DAX
  • Opérateurs de comparaison DAX
  • Opérateur de concaténation de texte DAX
  • Opérateurs logiques DAX

Ordre de priorité des opérateurs DAX

Vous pouvez avoir une formule DAX avec de nombreux opérateurs DAX combinant plusieurs valeurs ou expressions. Dans un tel cas, le résultat final dépendra de l'ordre dans lequel les opérations sont effectuées. DAX vous fournit l'ordre de priorité des opérateurs par défaut ainsi que des moyens de remplacer l'ordre de priorité par défaut.

La priorité des opérateurs par défaut DAX est répertoriée dans le tableau suivant.

Ordre de préséance Les opérateurs) Opération
1 ^ Exponentiation
2 - Signe
3 * et / Multiplication et division
4 ! NE PAS
5 + et - Addition et soustraction
6 & Enchaînement
sept =, <,>, <=,> = et <> Égal à, inférieur à, supérieur à, inférieur ou égal à, supérieur ou égal à et différent de

Syntaxe d'expression DAX

Vous devez d'abord comprendre la syntaxe de l'expression DAX et la façon dont l'évaluation de l'expression est effectuée avec les opérandes et les opérateurs.

  • Toutes les expressions commencent toujours par un signe égal (=). Le signe égal indique que les caractères suivants constituent une expression.

  • À droite du signe égal, vous aurez les opérandes connectés par les opérateurs DAX. Par exemple, = 5 + 4> 5.

    = 5 * 6 - 3.

  • Les expressions sont toujours lues de gauche à droite et les calculs sont effectués dans cette séquence, en fonction de la priorité des opérateurs DAX donnée dans la section précédente.

  • Si les opérateurs DAX ont une valeur de priorité égale, ils sont évalués de gauche à droite. Par exemple, = 5 * 6/10. Les deux * et / ont le même ordre précédent. Par conséquent, l'expression est évaluée comme 30/10 = 3.

  • Si les opérateurs DAX de l'expression ont des valeurs de priorité différentes, ils sont évalués dans l'ordre de priorité de gauche à droite.

    • = 5 + 4> 7. La priorité par défaut est + premier et> suivant. Par conséquent, l'expression est calculée de gauche à droite. - 5 + 4 est d'abord calculé, ce qui donne 9, puis 9> 5 est évalué, ce qui donne VRAI.

    • = 5 * 6 - 3. La priorité par défaut est * premier et - suivant. Par conséquent, l'expression est calculée de gauche à droite. - 5 * 6 est d'abord calculé, ce qui donne 30, puis 30 - 3 est calculé, ce qui donne 27.

    • = 2 * 5 - 6 * 3. La priorité par défaut est * d'abord, * suivant et ensuite -. Par conséquent, l'expression est évaluée à 10 - 18, puis à -8. Notez que ce n'est pas 10 - 6, ce qui donne 4 puis 4 * 3, soit 12.

Utilisation de parenthèses pour contrôler l'ordre de calcul DAX

Vous pouvez modifier l'ordre de priorité des opérateurs DAX par défaut en utilisant des parenthèses, en regroupant les opérandes et les opérateurs pour contrôler la séquence de calcul.

Par exemple, = 5 * 6 - 3 est évalué à 27 avec l'ordre de priorité des opérateurs par défaut DAX. Si vous utilisez des parenthèses pour regrouper les opérandes et les opérateurs sous la forme = 5 * (6 - 3), alors 6 - 3 est d'abord calculé, ce qui donne 3, puis 5 * 3 est calculé, ce qui donne 15.

= 2 * 5 - 6 * 3 est évalué à -8 avec l'ordre de priorité des opérateurs par défaut DAX. Si vous utilisez des parenthèses pour regrouper les opérandes et les opérateurs sous la forme = 2 * (5 - 6) * 3, alors 5 - 6 est d'abord calculé, ce qui donne -1, puis 2 * (-1) * 3 est calculé, ce qui donne -6 .

Comme vous pouvez le voir, avec les mêmes opérandes et opérateurs, différents résultats sont possibles selon la façon dont vous les groupez. Par conséquent, lorsque vous utilisez les opérateurs DAX dans les formules DAX, vous devez faire attention à la façon dont la séquence de calcul doit être.

Différences entre Excel et DAX

Bien que DAX présente des similitudes avec les formules Excel, il existe certaines différences significatives entre les deux.

  • DAX est plus puissant qu'Excel en raison de son moteur de calcul résidant en mémoire sous-jacent.

  • DAX prend en charge plus de types de données qu'Excel.

  • DAX fournit des fonctionnalités avancées supplémentaires d'une base de données relationnelle, un modèle de données, y compris une prise en charge plus riche des types de date et d'heure.

Dans certains cas, les résultats des calculs ou le comportement des fonctions dans DAX peuvent ne pas être les mêmes que dans Excel. Cela est dû aux différences dans ce qui suit -

  • Diffusion de types de données
  • Types de données

Différence de conversion de type de données

Dans DAX, lorsque vous avez un opérateur expression = valeur1, valeur2, les deux opérandes valeur1 et valeur2 doivent être du même type de données. Si les types de données sont différents, DAX les convertit d'abord en un type de données commun implicitement. Reportez-vous au chapitre - Syntaxe DAX pour plus de détails.

Par exemple, vous devez comparer deux opérandes de types de données différents, par exemple un nombre résultant d'une formule, telle que = [Montant] * 0,08 et un entier. Le premier nombre peut être un nombre décimal avec plusieurs décimales, tandis que le deuxième nombre est un entier. Ensuite, DAX le gère comme suit -

  • Tout d'abord, DAX convertira les deux opérandes en nombres réels en utilisant le plus grand format numérique pouvant stocker les deux types de nombres.

  • Ensuite, DAX comparera les deux nombres réels.

En revanche, Excel essaie de comparer les valeurs de différents types de données sans les forcer d'abord à un type de données commun. Pour cette raison, vous pouvez trouver des résultats différents dans DAX et dans Excel pour la même expression de comparaison.

Différence de types de données

L'ordre de priorité des opérateurs dans DAX et Excel est le même. Cependant, l'opérateur pour cent (%) et les plages de données pris en charge par Excel ne sont pas pris en charge par DAX. De plus, DAX prend en charge la table en tant que type de données, ce qui n'est pas le cas dans Excel.

En outre, dans les formules Excel, vous pouvez faire référence à une seule cellule, à un tableau ou à une plage de cellules. Dans les formules DAX, vous ne pouvez faire référence à aucun de ces éléments. Les références de formule DAX aux données doivent être par tables, colonnes, champs calculés et colonnes calculées.

Si vous copiez des formules à partir d'Excel et les collez dans DAX, assurez-vous que la formule DAX est correcte car la syntaxe DAX est différente de la syntaxe de formule Excel. De plus, même si une fonction porte le même nom dans DAX et Excel, ses paramètres peuvent être différents et le résultat de la fonction peut également être différent.

Vous en apprendrez plus sur tout cela dans les chapitres suivants.

Excel DAX - Paramètres standard

DAX a standard parameternoms pour faciliter l'utilisation et la compréhension des fonctions DAX. De plus, vous pouvez utiliser certains préfixes pour les noms de paramètres. Si le préfixe est suffisamment clair, vous pouvez utiliser le préfixe lui-même comme nom de paramètre.

Noms de paramètres standard

Voici les noms des paramètres standard DAX -

Sr.No. Nom et description du paramètre
1

expression

Toute expression DAX qui renvoie une seule valeur scalaire, où l'expression doit être évaluée plusieurs fois (pour chaque ligne / contexte).

2

value

Toute expression DAX qui renvoie une valeur scalaire unique où l'expression doit être évaluée exactement une fois avant toutes les autres opérations.

3

table

Toute expression DAX qui renvoie une table de données.

4

tableName

Le nom d'une table existante utilisant la syntaxe DAX standard. Cela ne peut pas être une expression.

5

columnName

Le nom d'une colonne existante utilisant la syntaxe DAX standard, généralement pleinement qualifiée. Cela ne peut pas être une expression.

6

name

Une constante de chaîne qui sera utilisée pour fournir le nom d'un nouvel objet.

sept

order

Une énumération utilisée pour déterminer l'ordre de tri.

8

ties

Une énumération utilisée pour déterminer la gestion des valeurs de lien.

9

type

Énumération utilisée pour déterminer le type de données pour PathItem et PathItemReverse.

Préfixer les noms de paramètres

Vous pouvez qualifier un nom de paramètre avec un préfixe -

  • Le préfixe doit être descriptif de la manière dont l'argument est utilisé.

  • Le préfixe doit être tel qu'une lecture ambiguë du paramètre est évitée.

Par exemple,

  • Result_ColumnName - Fait référence à une colonne existante utilisée pour obtenir les valeurs de résultat dans la fonction DAX LOOKUPVALUE ().

  • Search_ColumnName - Fait référence à une colonne existante utilisée pour rechercher une valeur dans la fonction DAX LOOKUPVALUE ().

Utiliser uniquement le préfixe comme paramètre

Vous pouvez omettre le nom du paramètre et n'utiliser que le préfixe, si le préfixe est suffisamment clair pour décrire le paramètre. Omettre le nom du paramètre et n'utiliser que le préfixe peut parfois aider à éviter l'encombrement de la lecture.

Par exemple, considérez DATE (Year_value, Month_value, Day_value). Vous pouvez omettre le nom du paramètre - valeur, qui est répété trois fois et l'écrire comme DATE (année, mois, jour). Comme vous pouvez le constater, en utilisant uniquement les préfixes, la fonction est plus lisible.

Cependant, parfois, le nom du paramètre et le préfixe doivent être présents pour plus de clarté.

Par exemple, considérez Year_columnName. Le nom du paramètre est ColumnName et le préfixe est Year. Les deux sont nécessaires pour faire comprendre à l'utilisateur que le paramètre nécessite une référence à la colonne d'années existante.

Excel DAX - Fonctions

La plupart DAX functionsont les mêmes noms et fonctionnalités que ceux des fonctions Excel. Cependant, les fonctions DAX ont été modifiées pour utiliser les types de données DAX et travailler avec des tables et des colonnes.

DAX a quelques fonctions supplémentaires que vous ne trouverez pas dans Excel. Ces fonctions DAX sont fournies à des fins spécifiques telles que des recherches basées sur des relations associées aux aspects de base de données relationnelle du modèle de données, la capacité d'itérer sur une table pour effectuer des calculs récursifs, pour effectuer une agrégation dynamique et pour des calculs utilisant l'intelligence temporelle.

Dans ce chapitre, vous découvrirez les fonctions prises en charge dans le langage DAX. Pour plus d'informations sur l'utilisation de ces fonctions DAX, reportez-vous au didacticiel - Fonctions DAX dans cette bibliothèque de didacticiels.

Qu'est-ce qu'une fonction DAX?

Une fonction DAX est une fonction intégrée fournie dans le langage DAX pour vous permettre d'effectuer diverses actions sur les données des tables de votre modèle de données. Comme indiqué précédemment, DAX est utilisé à des fins d'analyse de données et de veille stratégique qui nécessitent une prise en charge pour extraire, assimiler et tirer des informations à partir des données. Les fonctions DAX basées sur le modèle de données vous fournissent ces utilitaires qui simplifient votre travail, une fois que vous maîtrisez le langage DAX et l'utilisation des fonctions DAX.

Fonctions Excel et fonctions DAX

Il existe certaines similitudes entre les fonctions Excel dont vous avez connaissance et les fonctions DAX. Cependant, il existe également certaines différences. Vous devez obtenir des précisions à ce sujet, afin d'éviter de faire des erreurs dans l'utilisation des fonctions DAX et dans l'écriture de formules DAX qui incluent des fonctions DAX.

Similitudes entre les fonctions Excel et les fonctions DAX

  • De nombreuses fonctions DAX ont le même nom et le même comportement général que les fonctions Excel.

  • DAX a des fonctions de recherche similaires aux fonctions de recherche de tableau et de vecteur dans Excel.

Différences entre les fonctions Excel et les fonctions DAX

  • Les fonctions DAX ont été modifiées pour accepter différents types d'entrées et certaines des fonctions DAX peuvent renvoyer un type de données différent. Par conséquent, vous devez comprendre l'utilisation de ces fonctions séparément, bien qu'elles portent le même nom. Dans ce tutoriel, vous trouverez chaque fonction DAX préfixée par DAX afin d'éviter toute confusion avec les fonctions Excel.

  • Vous ne pouvez pas utiliser des fonctions DAX dans une formule Excel ou utiliser des formules / fonctions Excel dans DAX, sans les modifications requises.

  • Les fonctions Excel prennent une référence de cellule ou une plage de cellules comme référence. Les fonctions DAX ne prennent jamais une référence de cellule ou une plage de cellules comme référence, mais prennent plutôt une colonne ou un tableau comme référence.

  • Les fonctions de date et d'heure Excel renvoient un entier qui représente une date sous forme de numéro de série. Les fonctions de date et d'heure DAX renvoient un type de données datetime qui se trouve dans DAX mais pas dans Excel.

  • Excel n'a pas de fonctions qui renvoient un tableau, mais certaines fonctions peuvent fonctionner avec des tableaux. De nombreuses fonctions DAX peuvent facilement référencer des tables et des colonnes complètes pour effectuer des calculs et renvoyer une table ou une colonne de valeurs. Cette capacité de DAX ajoute de la puissance à Power Pivot, Power View et Power BI, où DAX est utilisé.

  • Les fonctions de recherche DAX nécessitent qu'une relation soit établie entre les tables.

  • Excel prend en charge le type de données variante dans une colonne de données, c'est-à-dire que vous pouvez avoir des données de différents types de données dans une colonne. Alors que DAX s'attend à ce que les données d'une colonne d'une table soient toujours du même type de données. Si les données ne sont pas du même type de données, DAX remplace la colonne entière par le type de données qui accepte le mieux toutes les valeurs de la colonne. Cependant, si les données sont importées et que ce problème survient, DAX peut signaler une erreur.

Pour en savoir plus sur les types de données DAX et la conversion des types de données, reportez-vous au chapitre - Référence de la syntaxe DAX.

Types de fonctions DAX

DAX prend en charge les types de fonctions suivants.

  • Fonctions valorisées de la table DAX
    • Fonctions de filtre DAX
    • Fonctions d'agrégation DAX
    • Fonctions DAX Time Intelligence
  • Fonctions de date et d'heure DAX
  • Fonctions d'informations DAX
  • Fonctions logiques DAX
  • Fonctions mathématiques et de déclenchement DAX
  • Autres fonctions DAX
  • Fonctions parent et enfant DAX
  • Fonctions statistiques DAX
  • Fonctions de texte DAX

Dans cette section, vous découvrirez les fonctions DAX au niveau des catégories de fonctions. Pour plus de détails sur la syntaxe de la fonction DAX et ce que la fonction DAX renvoie et fait, reportez-vous au didacticiel sur les fonctions DAX de cette bibliothèque de didacticiels.

Les fonctions d'intelligence temporelle DAX et les fonctions de filtre DAX sont puissantes et nécessitent une mention spéciale. Reportez-vous aux chapitres - Comprendre les fonctions DAX Time Intelligence et DAX Filter pour plus de détails.

Fonctions valorisées de la table DAX

De nombreuses fonctions DAX prennent des tables comme tables d'entrée ou de sortie ou font les deux. Ces fonctions DAX sont appelées fonctions de table DAX. Étant donné qu'une table peut avoir une seule colonne, les fonctions de table DAX prennent également des colonnes uniques comme entrées. Vous disposez des types suivants de fonctions de table DAX -

  • Fonctions d'agrégation DAX
  • Fonctions de filtre DAX
  • Fonctions DAX Time Intelligence

Comprendre les fonctions de table DAX vous aide à écrire efficacement des formules DAX.

Fonctions d'agrégation DAX

Les fonctions d'agrégation DAX agrègent toute expression sur les lignes d'une table et sont utiles dans les calculs.

Voici quelques fonctions d'agrégation DAX -

  • ADDCOLUMNS (<table>, <nom>, <expression>, [<nom>, <expression>]…)

  • MOYENNE (<colonne>)

  • MOYENNEA (<colonne>)

  • AVERAGEX (<table>, <expression>)

  • COUNT (<colonne>)

  • COUNTA (<colonne>)

  • COUNTAX (<table>, <expression>)

  • COUNTBLANK (<colonne>)

  • COUNTROWS (<table>)

  • COUNTX (<table>, <expression>)

  • CROSSJOIN (<table1>, <table2>, [<table3>]…)

  • DISTINCTCOUNT (<colonne>)

  • GÉNÉRER (<table1>, <table2>)

  • GÉNÉRER TOUT (<table1>, <table2>)

  • MAX (<colonne>)

  • MAXA (<colonne>)

  • MAXX (<table>, <expression>)

  • MIN (<colonne>)

  • MINA (<colonne>)

  • MINX (<table>, <expression>)

  • PRODUIT (<colonne>)

  • PRODUCTX (<table>, <expression>)

  • ROW (<nom>, <expression>, [<nom>, <expression>]…)

  • SELECTCOLUMNS (<table>, <nom>, <expression_calaire>,

  • [<nom>, <expression_scalaire>]…)

  • SOMME (<colonne>)

  • SUMMARIZE (<table>, <groupBy_columnName>, [<groupBy_columnName>]…, [<name>, <expression>]…)

  • SUMX (<table>, <expression>)

  • TOPN (<n_valeur>, <table>, <orderBy_expression>, [<order>], [<orderBy_expression>, [<order>]]…)

Fonctions de filtre DAX

Les fonctions de filtre DAX renvoient une colonne, une table ou des valeurs liées à la ligne actuelle. Vous pouvez utiliser les fonctions de filtre DAX pour renvoyer des types de données spécifiques, rechercher des valeurs dans des tables associées et filtrer par valeurs associées. Les fonctions de recherche DAX fonctionnent en utilisant des tables et des relations entre elles. Les fonctions de filtre DAX vous permettent de manipuler le contexte des données pour créer des calculs dynamiques.

Voici quelques fonctions de filtre DAX -

  • ADDMISSINGITEMS (<showAllColumn>, [<showAllColumn>]…, <table>, <groupingColumn>, [<groupingColumn>]… [filterTable]…)

  • TOUT ({<table> | <colonne>, [<colonne>], [<colonne>]…})

  • ALLEXCEPT (<table>, <colonne>, [<colonne>]…)

  • ALLNOBLANKROW(<table>|<column>)

  • ALLSELECTED ([<tableName> | <columnName>])

  • CALCULER (<expression>, <filter1>, <filter2>…)

  • CALCULATETABLE (<expression>, <filter1>, <filter2>…)

  • CROSSFILTER (<columnName1>, <columnName2>, <direction>)

  • DISTINCT (<colonne>)

  • EARLIER (<colonne>, <numéro>)

  • EARLIEST(<column>)

  • FILTER(<table>,<filter>)

  • FILTERS(<columnName>)

  • HASONEFILTER(<columnName>)

  • HASONEVALUE(<columnName>)

  • ISCROSSFILTERED (<nomcolonne>)

  • ISFILTERED (<nomcolonne>)

  • KEEPFILTERS (<expression>)

  • RELATED(<column>)

  • RELATEDTABLE(<tableName>)

  • SUBSTITUTEWITHINDEX (<table>, <indexColumnName>, <indexColumnsTable>, <orderBy_expression>, [<order>], [<orderBy_expression>, [<order>]]…])

  • USERELATIONSHIP(<columnName1>,<columnName2>)

  • VALUES(<TableNameOrColumnName>)

Fonctions DAX Time Intelligence

Les fonctions DAX Time Intelligence renvoient une table de dates ou utilisent une table de dates pour calculer une agrégation. Ces fonctions DAX vous aident à créer des calculs qui prennent en charge les besoins de l'analyse de Business Intelligence en vous permettant de manipuler des données en utilisant des périodes de temps, y compris des jours, des mois, des trimestres et des années.

Voici quelques fonctions de DAX Time Intelligence -

  • CLOSINGBALANCEMONTH (<expression>, <dates> [, <filter>])

  • CLOSINGBALANCEQUARTER (<expression>, <dates>, [<filter>])

  • CLOSINGBALANCEYEAR (<expression>, <dates>, [<filter>], [<year_end_date>])

  • DATEADD (<dates>, <number_of_intervals>, <interval>)

  • DATESBETWEEN (<dates>, <start_date>, <end_date>)

  • DATESINPERIOD (<dates>, <start_date>, <number_of_intervals>, <interval>)

  • DATESMTD (<dates>)

  • DATESQTD (<dates>)

  • DATESYTD (<dates>, [<year_end_date>])

  • ENDOFMONTH (<dates>)

  • FIN DU QUARTIER (<dates>)

  • ENDOFYEAR (<dates>, [<year_end_date>])

  • FIRSTDATE (<dates>)

  • FIRSTNONBLANK (<colonne>, <expression>)

  • LASTDATE (<dates>)

  • LASTNONBLANK (<colonne>, <expression>)

  • NEXTDAY (<dates>)

  • NEXTMONTH (<dates>)

  • QUARTIER SUIVANT (<dates>)

  • NEXTYEAR (<dates>, [<year_end_date>])

  • OPENINGBALANCEMONTH (<expression>, <dates>, [<filter>])

  • OPENINGBALANCEQUARTER (<expression>, <dates>, [<filter>])

  • OPENINGBALANCEYEAR (<expression>, <dates>, [<filter>], [<year_end_date>])

  • PARALLELPERIOD (<dates>, <number_of_intervals>, <interval>)

  • PREVIOUSDAY(<dates>)

  • PREVIOUSMONTH(<dates>)

  • PREVIOUSQUARTER(<dates>)

  • PREVIOUSYEAR (<dates>, [<year_end_date>])

  • SAMEPERIODLASTYEAR(<dates>)

  • STARTOFMONTH(<dates>)

  • STARTOFQUARTER(<dates>)

  • STARTOFYEAR(<dates>)

  • TOTALMTD (<expression>, <dates>, [<filtre>])

  • TOTALQTD (<expression>, <dates>, [<filtre>])

  • TOTALYTD (<expression>, <dates>, [<filter>], [<year_end_date>])

Fonctions de date et d'heure DAX

Les fonctions de date et d'heure DAX sont similaires aux fonctions de date et d'heure d'Excel. Cependant, les fonctions de date et d'heure DAX sont basées sur le type de données datetime de DAX.

Voici les fonctions de date et d'heure DAX -

  • DATE (<année>, <mois>, <jour>)
  • DATEVALUE(date_text)
  • DAY(<date>)
  • EDATE (<date_début>, <mois>)
  • EOMONTH (<date_début>, <mois>)
  • HOUR(<datetime>)
  • MINUTE(<datetime>)
  • MONTH(<datetime>)
  • NOW()
  • SECOND(<time>)
  • TIME (heure, minute, seconde)
  • TIMEVALUE(time_text)
  • TODAY()
  • WEEKDAY (<date>, <return_type>)
  • SEMAINE (<date>, <type_retour>)
  • YEAR(<date>)
  • YEARFRAC (<start_date>, <end_date>, <basis>)

Fonctions d'informations DAX

Les fonctions d'informations DAX examinent la cellule ou la ligne fournie en tant qu'argument et vous indiquent si la valeur correspond au type attendu.

Voici quelques fonctions d'informations DAX -

  • CONTIENT (<table>, <columnName>, <value>, [<columnName>, <value>]…)

  • CUSTOMDATA()

  • ISBLANK(<value>)

  • ISERROR(<value>)

  • ISEVEN(number)

  • ISLOGICAL(<value>)

  • ISNONTEXT(<value>)

  • ISNUMBER(<value>)

  • ISONORAFTER (<expression_calaire>, <expression_calaire>, [ordre_tri], [<expression_calaire>, <expression_calaire>, [ordre_ tri]]…)

  • ISTEXT(<value>)

  • LOOKUPVALUE (<result_columnName>, <search_columnName>, <search_value>, [<search_columnName>, <search_value>]…)

  • USERNAME()

Fonctions logiques DAX

Les fonctions logiques DAX renvoient des informations sur les valeurs d'une expression. Par exemple, la fonction DAX TRUE vous permet de savoir si une expression que vous évaluez renvoie une valeur TRUE.

Voici les fonctions logiques DAX -

  • AND(<logical1>,<logical2>)
  • FALSE()
  • IF (test_logique>, <value_if_true>, value_if_false)
  • IFERROR (valeur, valeur_if_error)
  • NOT(<logical>)
  • OR(<logical1>,<logical2>)
  • SWITCH (<expression>, <valeur>, <résultat>, [<valeur>, <résultat>]…, [<else>])
  • TRUE()

Fonctions mathématiques et de déclenchement DAX

Les fonctions mathématiques et trigonométriques DAX sont très similaires aux fonctions mathématiques et trigonométriques d'Excel.

Voici quelques fonctions DAX Math et Trig -

  • ABS(<number>)
  • ACOS(number)
  • ACOSH(number)
  • ASIN(number)
  • ASINH(number)
  • ATAN(number)
  • ATANH(number)
  • PLAFOND (<numéro>, <importance>)
  • COMBIN (nombre, nombre_choisi)
  • COMBINA (nombre, nombre_choisi)
  • COS(number)
  • COSH(number)
  • CURRENCY(<value>)
  • DEGREES(angle)
  • DIVIDE (<numérateur>, <dénominateur>, [<alternateresult>])
  • EVEN(number)
  • EXP(<number>)
  • FACT(<number>)
  • PLANCHER (<numéro>, <importance>)
  • GCD (numéro1, [numéro2], ...)
  • INT(<number>)
  • PLAFOND ISO (<numéro>, [<importance>])
  • LCM (numéro1, [numéro2], ...)
  • LN(<number>)
  • LOG(<number>,<base>)
  • LOG10(<number>)
  • INT(<number>)
  • MROUND (<numéro>, <multiple>)
  • ODD(number)
  • PI()
  • PUISSANCE (<numéro>, <puissance>)
  • PRODUCT(<column>)
  • PRODUCTX (<table>, <expression>)
  • QUOTIENT (<numérateur>, <dénominateur>)
  • RADIANS(angle)
  • RAND()
  • RANDBETWEEN(<bottom>,<top>)
  • ROUND (<nombre>, <num_digits>)
  • ROUNDDOWN (<nombre>, <num_digits>)
  • ROUNDUP (<nombre>, <num_digits>)
  • SIN(number)
  • SINH(number)
  • SIGN(<number>)
  • SQRT(<number>)
  • SUM(<column>)
  • SUMX (<table>, <expression>)
  • TAN(number)
  • TANH(number)
  • TRUNC(<number>,<num_digits>)

Autres fonctions DAX

Ces fonctions DAX exécutent des actions uniques qui ne peuvent être définies par aucune des catégories auxquelles appartiennent la plupart des autres fonctions.

Voici quelques autres fonctions DAX -

  • SAUF (<expression_table1>, <expression_table2>

  • GROUPBY (<table>, [<groupBy_columnName1>], [<nom>, <expression>]…)

  • INTERSECT (<expression_table1>, <expression_table2>)

  • ISEMPTY(<table_expression>)

  • NATURALINNERJOIN (<leftJoinTable>, <rightJoinTable>)

  • NATURALLEFTOUTERJOIN (<leftJoinTable>, <rightJoinTable>)

  • SUMMARIZECOLUMNS (<groupBy_columnName>, [<groupBy_columnName>]…, [<filterTable>]…, [<name>, <expression>]…)

  • UNION (<table_expression1>, <table_expression2>, [<table_expression>]…)

  • VAR <nom> = <expression>

Fonctions parent et enfant DAX

Les fonctions parent et enfant DAX sont utiles pour gérer les données présentées sous forme de hiérarchie parent / enfant dans le modèle de données.

Voici quelques fonctions parent et enfant DAX -

  • CHEMIN (<ID_columnName>, <parent_columnName>)
  • PATHCONTAINS (<chemin>, <item>)
  • PATHITEM (<chemin>, <position>, [<type>])
  • PATHITEMREVERSE (<chemin>, <position>, [<type>])
  • PATHLENGTH(<path>)

Fonctions statistiques DAX

Les fonctions statistiques DAX sont très similaires aux fonctions statistiques Excel.

Voici quelques fonctions statistiques DAX -

  • BETA.DIST (x, alpha, bêta, cumulatif, [A], [B])

  • BETA.INV (probabilité, alpha, bêta, [A], [B])

  • CHISQ.INV (probabilité, deg_liberté)

  • CHISQ.INV.RT (probabilité, deg_liberté)

  • CONFIDENCE.NORM (alpha, standard_dev, taille)

  • CONFIDENCE.T (alpha, standard_dev, taille)

  • DATATABLE (ColumnName1, DataType1, ColumnName2, DataType2 ..., {{Value1, Value2 ...}, {ValueN, ValueN + 1 ...} ...})

  • EXPON.DIST (x, lambda, cumulatif)

  • GEOMEAN(<column>)

  • GEOMEANX(<table>, <expression>)

  • MEDIAN(<column>)

  • MEDIANX(<table>, <expression>)

  • PERCENTILE.EXC(<column>, <k>)

  • PERCENTILE.INC(<column>, <k>)

  • PERCENTILEX.EXC(<table>, <expression>, k)

  • PERCENTILEX.EXC(<table>, <expression>, k)

  • POISSON.DIST(x, mean, cumulative)

  • RANK.EQ(<value>, <columnName>[, <order>])

  • RANKX(<table>, <expression>[, <value>[, <order>[, <ties>]]])

  • SAMPLE (<n_value>, <table>, <orderBy_expression>, [<order>], [<orderBy_expression>, [<order>]]…)

  • STDEV.P(<ColumnName>)

  • STDEV.S(<ColumnName>)

  • STDEVX.P(<table>, <expression>)

  • STDEVX.S(<table>, <expression>)

  • SQRTPI(number)

  • VAR.P(<columnName>)

  • VAR.S(<columnName>)

  • VARX.P(<table>, <expression>)

  • VARX.S(<table>, <expression>)

  • XIRR(<table>, <values>, <dates>, [guess])

  • XNPV(<table>, <values>, <dates>, <rate>)

DAX Text Functions

DAX Text functions work with tables and columns. With DAX Text functions you can return the part of a string, search for text within a string or concatenate string values. You can also control the formats for dates, times, and numbers.

Following are some DAX Text functions −

  • BLANK()
  • CODE(text)
  • CONCATENATE(<text1>, <text2>)
  • CONCATENATEX(<table>, <expression>, [delimiter])
  • EXACT(<text1>,<text2>)
  • FIND(<find_text>, <within_text>, [<start_num>], [<NotFoundValue>])
  • FIXED(<number>, <decimals>, <no_commas>)
  • FORMAT(<value>, <format_string>)
  • LEFT(<text>, <num_chars>)
  • LEN(<text>)
  • LOWER(<text>)
  • MID(<text>, <start_num>, <num_chars>)
  • REPLACE(<old_text>, <start_num>, <num_chars>, <new_text>)
  • REPT(<text>, <num_times>)
  • RIGHT(<text>, <num_chars>)
  • SEARCH(<find_text>, <within_text>, [<start_num>], [<NotFoundValue>])
  • SUBSTITUTE(<text>, <old_text>, <new_text>, <instance_num>)
  • TRIM(<text>)
  • UPPER (<text>)
  • VALUE(<text>)

Excel DAX - Understanding DAX Functions

In Excel 2013, DAX has 246 functions. You have already learnt about the different types of DAX functions in the chapter – DAX Functions. However, if you have to use a DAX function in a DAX formula, you need to understand the function in detail. You should know the syntax of the function, the parameter types, what the function returns, etc.

If you are writing a DAX formula, it is suggested to use the DAX functions where applicable. For this, you can refer to the tutorial – DAX Functions in this tutorials library for an indepth understanding of where and how to use each of the 246 DAX functions. You can always go back and forth between this tutorial and DAX Functions tutorial to obtain mastery on DAX.

In this chapter, you will understand how to read and interpret the DAX functions in the DAX Functions tutorial.

DAX Function – Explanation Structure

In the DAX functions tutorial, each DAX function is explained in a standard structure, comprising of the following sections −

  • Description
  • Syntax
  • Parameters
  • Return Value
  • Remarks
  • Example

You will learn about each of these in the following sections.

Description

In the Description section, you will learn what the DAX function is about and where it can be used.

Syntax

In the Syntax section, you will learn the exact function name and the respective parameters.

Parameters

In the Parameters section, you will learn about each of the parameters of the specific DAX function, whether a parameter is an input or an output and if there are any options. As seen in the chapter - DAX Standard Parameters, only the standard parameter names will be used.

Return Value

In the Return Value section, you will learn about what value the DAX function will return and its data type.

Remarks

In the Remarks section, you will learn about any extra information that you need to know about the usage of the DAX function.

Example

The DAX function description will be ended with an example of the usage of the function.

Excel DAX - Evaluation Context

In DAX, context is an important term that you should be aware of, while writing DAX formulas. Also referred to as evaluation context, DAX context is used to determine the evaluation of a DAX formula and the corresponding result. This means, the results of a DAX formula can vary according to the context. You should clearly understand how a specific DAX context is used and how the results can be different.

Evaluation context enables you to perform dynamic analysis, in which the results of a DAX formula can change to reflect the current row or a cell selection and also any related data. Understanding context and using context effectively are very important to build powerful DAX formulas, perform dynamic data analysis, and troubleshoot problems in DAX formulas. Evaluation contexts are the basis of all of the advanced features of DAX that you need to master to create complex data analysis reports.

As you keep referencing to DAX functions for relevant usage in DAX formulas, you need to refer to this chapter on DAX context to obtain clarity on the results.

Types of Context in DAX

DAX supports the following evaluation contexts −

  • Row Context
  • Filter Context

When a DAX formula is evaluated, all the contexts will be taken into account and are applied as relevant. The contexts exist together and the result of the formula will be different based on the context that is used while calculating a value. For example, when you select fields for rows, columns, and filters in a PivotTable, the subtotals are dynamically calculated based on which row and which column the subtotal/total is associated with and the values in the rows and columns are determined by the filters used.

Row Context

Row context means that the DAX formula or the DAX function knows which row of the table it is referencing at any point in time. You can consider row context as the current row. The formula will get calculated row-by-row with the row context.

Some DAX functions (e.g., the X-functions, FILTER ()) and all calculated columns have a row context. For example, if you create a calculated column Year with the DAX formula = YEAR ([Date]), the values of the calculated column are obtained by applying the given DAX formula on the given column in the table, row by row.

This means that if you have created a calculated column, the row context consists of the values in each individual row and the values in the columns that are related to the current row, as determined by the DAX formula used. Though the DAX formula does not contain the reference to a row, DAX implicitly understands the row context while calculating values.

DAX creates a row context automatically when you define a calculated column and all the calculated values with the DAX formula used will appear in the calculated column.

In contrast, when you have a DAX function such as SUMX, the values calculated row by row get summed up and only the final result will be displayed. That is, the intermediate values are discarded.

When you have related tables, the row context determines which rows in the related table are associated with the current row. However, the row context does not propagate through relationships automatically. You have to use the DAX functions - RELATED and RELATEDTABLE for this.

Multiple Row Context

DAX has iterator functions like SUMX. You can use these functions to nest row contexts. With this, programmatically you can have a recursion over an inner loop and an outer loop, where you can have multiple current rows and current row contexts.

For example, you can use the DAX function Earlier () that stores the row context from the operation that preceded the current operation. This function stores two sets of context in memory - one set of context represents the current row for the inner loop of the formula, and another set of context represents the current row for the outer loop of the formula. DAX automatically feeds the values between the two loops so that you can create complex aggregates.

For an example, refer to the scenario - Creating a DAX Formula that Dynamically Ranks Values in the chapter Scenarios - Ranking and Comparing Values.

Filter Context

Filter context refers to any filtering that is applied to the Data Model in DAX. Filter context is created by a PivotTable and also by the DAX functions.

Filter Context Created by a PivotTable

Filter Context created by a PivotTable is the natural filtering that is applied by the selections made on the PivotTable fields from the following −

  • Rows
  • Columns
  • Filters
  • Slicers

The filter context created by a PivotTable, filters the underlying tables in the Data Model. If the tables are related, then the filters flow down from the lookup tables to data tables. That means, you can filter the data tables based on the results from the lookup tables. The filter propagation does not happen the other way round. However, you can use DAX formulas to filter the lookup tables based on the results from the data tables.

Filter Context Created by DAX Functions

You can use DAX Filter functions to define calculated fields and calculated columns, containing filter expressions that control the values used by the DAX formula. These calculated fields and calculated columns then become part of the PivotTable fields list and you can add them to the PivotTable. You can also selectively clear the filters on particular columns with these DAX Filter functions. An example of a powerful DAX Filter function to create Filter Context is CALCULATE (). For an example, refer to the chapter Scenarios - Performing Complex Calculations.

Filter Context as an Addition to Row Context

Row context does not automatically create a filter context. You can achieve the same with the DAX formulas containing DAX Filter functions.

Excel DAX - Formulas

DAX is a formula language for creating custom calculations in Power PivotTables. You can use the DAX functions that are designed to work with relational data and perform dynamic aggregation in DAX formulas.

DAX formulas are very similar to Excel formulas. To create a DAX formula, you type an equal sign, followed by a function name or expression and any required values or arguments.

DAX Functions vs. DAX Formulas

DAX formulas can include DAX functions and leverage their usage. This is where DAX formulas tend to differ from DAX functions in important ways.

  • A DAX function always reference a complete column or a table. If you want to use only particular values from a table or column, you can add filters to the formula.

  • If you want to customize calculations on a row by row basis, Power Pivot provides functions that let you use the current row value or a related value to perform calculations that vary by context.

  • DAX includes a type of function that returns a table as its result, rather than a single value. These functions can be used to provide input to other functions, thus calculating values for entire tables or columns.

  • Some DAX functions provide time intelligence, which lets you create calculations using meaningful ranges of dates and compare the results across parallel periods.

Understanding DAX Formula Syntax

Every DAX formula has the following syntax −

  • Each formula must begin with an equal sign.

  • To the right of the equal sign, you can either type or select a function name, or type an expression. The expression can contain table names and column names connected by DAX operators.

Following are some valid DAX formulas −

  • [column_Cost] + [column_Tax]
  • = Today ()

Understanding IntelliSense Feature

DAX provides the IntelliSense feature that will enable you to write DAX formulas promptly and correctly. With this feature, you need not type the table, column, and function names completely, but select the relevant names from the dropdown list while writing a DAX formula.

  • Begin to type the first few letters of the function name. AutoComplete displays a list of available functions with the names beginning with those letters.

  • Place the pointer on any of the function names. IntelliSense tooltip will be displayed giving you the use of the function.

  • Click the function name. The function name appears in the formula bar and the syntax is displayed, which will guide you as you select the arguments.

  • Type the first letter of the table name that you want. AutoComplete displays a list of available tables and columns with the names beginning with that letter.

  • Press TAB or click the name to add an item from the AutoComplete list to the formula.

  • Click the Fx button to display a list of available functions. To select a function from the dropdown list, use the arrow keys to highlight the item and click OK to add the function to the formula.

  • Supply the arguments to the function by selecting them from a dropdown list of possible tables and columns or by typing in required values.

Usage of this handy IntelliSense feature is highly recommended.

Where to Use DAX Formulas?

You can use DAX formulas in creating calculated columns and calculated fields.

  • You can use DAX formulas in calculated columns, by adding a column and then typing an expression in the formula bar. You create these formulas in the PowerPivot window.

  • You can use DAX formulas in calculated fields. You create these formulas −

    • In the Excel window in the Calculated Field dialog box, or

    • In the Power Pivot window in the calculation area of a table.

The same formula can behave differently depending on whether the formula is used in a calculated column or a calculated field.

  • In a calculated column, the formula is always applied to every row in the column, throughout the table. Depending on the row context, the value might change.

  • In a calculated field, however, the calculation of results is strongly dependent on the context. That is, the design of the PivotTable and the choice of row and column headings affects the values that are used in calculations.

It is important to understand the concept of context in DAX to write DAX formulas. This can be a bit difficult in the beginning of your DAX journey, but once you get a grasp on it, you can write effective DAX formulas that are required for complex and dynamic data analysis. For details, refer to the chapter – DAX Context.

Creating a DAX Formula

You have already learnt about the IntelliSense feature in a previous section. Remember to use it while creating any DAX formula.

To create a DAX formula, use the following steps −

  • Type an equal sign.

  • To the right of the equal sign, type the following −

    • Type the first letter of a function or table name and select the complete name from the dropdown list.

    • If you have chosen a function name, type parenthesis ‘(‘.

    • If you have chosen the table name, type bracket ‘[‘. Type the first letter of the column name and select the complete name from the dropdown list.

    • Close the column names with ‘]’ and function names with ‘)’.

    • Type a DAX operator between expressions or type ‘,’ to separate function arguments.

    • Repeat steps 1 - 5 till the DAX formula is complete.

For example, you want to find the total sales amount in the East region. You can write a DAX formula as shown below. East_Sales is the name of the table. Amount is a column in the table.

SUM ([East_Sales[Amount])

As already discussed in the chapter – DAX Syntax, it is a recommended practice to use the table name along with the column name in every reference to any column name. This is termed as – “the fully qualified name”.

The DAX formula can vary based on whether it is for a calculated field or calculated column. Refer to the sections below for details.

Creating a DAX Formula for a Calculated Column

You can create a DAX formula for a calculated column in the Power Pivot window.

  • Click the tab of the table in which you want to add the calculated column.
  • Click the Design tab on the Ribbon.
  • Click Add.
  • Type the DAX formula for the calculated column in the formula bar.
= DIVIDE (East_Sales[Amount], East_Sales[Units])

This DAX formula does the following for every row in the table East_Sales −

  • Divides the value in Amount column of a row by the value in Units column in the same row.

  • Places the result in the new added column in the same row.

  • Repeats steps 1 and 2 iteratively till it completes all the rows in the table.

You have added a column for Unit Price at which those units are sold with the above formula.

  • As you can observe, calculated columns require computation and storage space as well. Hence, use calculated columns only if necessary. Use calculated fields where possible and sufficient.

Refer to the chapter - Calculated Columns for details.

Creating a DAX Formula for a Calculated Field

You can create a DAX formula for a calculated field either in the Excel window or in the Power Pivot window. In the case of calculated field, you need to provide the name beforehand.

  • To create a DAX formula for a calculated field in the Excel window, use the Calculated Field dialog box.

  • To create a DAX formula for a calculated field in the Power Pivot window, click a cell in the calculation area in the relevant table. Start the DAX formula with CalculatedFieldName:=.

For example, Total East Sales Amount:=SUM ([East_Sales[Amount])

If you use Calculated Field dialog box in the Excel window, you can check the formula before you save it and make it as a mandatory habit to ensure the use of correct formulas.

For more details on these options, refer to the chapter – Calculated Fields.

Creating DAX Formulas Using the Formula Bar

Power Pivot window also has a formula bar that is like Excel window formula bar. Formula bar makes it easier to create and edit formulas, using the AutoComplete functionality so as to minimize syntax errors.

  • To enter the name of a table, begin typing the name of the table. Formula AutoComplete provides a dropdown list containing valid table names that begin with those letters. You can start with one letter and type more letters to narrow down the list if required.

  • To enter the name of a column, you can select it from the list of column names in the selected table. Type a bracket ‘[‘, to the right of the table name, and then choose the column from the list of columns in the selected table.

Tips for Using AutoComplete

Following are some tips for using AutoComplete −

  • You can nest functions and formulas in a DAX formula. In such a case, you can use Formula AutoComplete in the middle of an existing formula with nested functions. The text immediately before the insertion point is used to display values in the dropdown list and all of the text after the insertion point remains unchanged.

  • Defined names that you create for constants do not get displayed in the AutoComplete dropdown list, but you can still type them.

  • The closing parenthesis of functions is not automatically added. You need to do it by yourself.

  • You must make sure that each function is syntactically correct.

Understanding Insert Function Feature

You can find the Insert Function button labelled as fx, both in the Power Pivot window and Excel window.

  • The Insert Function button in the Power Pivot window is to the left of formula bar.

  • The Insert Function button in the Excel window is in the Calculated Field dialog box to the right of Formula.

When you click on the fx button, Insert Function dialog box appears. The Insert Function dialog box is the easiest way to find a DAX function that is relevant to your DAX formula.

The Insert Function dialog box helps you select functions by category and provides short descriptions for each function.

Using Insert Function in a DAX Formula

Suppose you want to create the following calculated field −

Medal Count: = COUNTA (]Medal])

You can use Insert Function dialog box using the following steps −

  • Click the calculation area of the Results table.
  • Type the following in the formula bar −
Medal Count: =
  • Click the Insert Function button (fx).

Insert Function dialog box appears.

  • Select Statistical in the Select a category box as shown in the following screenshot.

  • Select COUNTA in the Select a function box as shown in the following screenshot.

As you can observe, the selected DAX function syntax and the function description are displayed. This enables you to make sure that it is the function that you want to insert.

  • Click OK. Medal Count:=COUNTA( appears in the formula bar and a tooltip displaying the function syntax also appears.

  • Type [. This means you are about to type a column name. The names of all the columns and the calculated fields in the current table will be displayed in the dropdown list. You can use IntelliSense to complete the formula.

  • Type M. The displayed names in the dropdown list will be limited to those starting with ‘M’.

  • Click Medal.

  • Double-click Medal. Medal Count: = COUNTA([Medal] will be displayed in the formula bar. Close the parenthesis.

  • Press Enter. You are done. You can use the same procedure to create a calculated column also. You can also follow the same steps to insert a function in the Calculated Field dialog box in the Excel window using the Insert Function feature.

  • Click the Insert Function (fx) button to the right of Formula.

Insert Function dialog box appears. The rest of the steps are the same as above.

Using Multiple Functions in a DAX Formula

DAX formulas can contain up to 64 nested functions. But, it is unlikely that a DAX formula contains so many nested functions.

If a DAX formula has many nested functions, it has the following disadvantages −

  • The formula would be very difficult to create.
  • If the formula has errors, it would be very difficult to debug.
  • The formula evaluation would not be very fast.

In such cases, you can split the formula into smaller manageable formulas and build the large formula incrementally.

Creating a DAX Formula Using Standard Aggregations

When you perform data analysis, you will perform calculations on aggregated data. There are several DAX aggregation functions, such as SUM, COUNT, MIN, MAX, DISTINCTCOUNT, etc. that you can use in DAX formulas.

You can automatically create formulas using standard aggregations by using the AutoSum feature in the Power Pivot window.

  • Click the Results tab in the Power Pivot window. Results table will be displayed.
  • Click the Medal column. The entire column – Medal will be selected.
  • Click the Home tab on the Ribbon.
  • Click the down arrow next to AutoSum in the Calculations group.
  • Click COUNT in the dropdown list.

As you can observe, the calculated field Count of Medal appears in the calculation area below the column – Medal. The DAX formula also appears in the formula bar −

Count of Medal: = COUNTA([Medal])

The AutoSum feature has done the work for you – created the calculated field for data aggregation. Further, AutoSum has taken the appropriate variant of the DAX function COUNT, i.e. COUNTA (DAX has COUNT, COUNTA, COUNTAX functions).

A word of caution – To use AutoSum feature, you need to click the down arrow next to AutoSum on the Ribbon. If you click on the AutoSum itself instead, you will get −

Sum of Medal: = SUM([Medal])

And an error is flagged as Medal is not a numeric data column and the text in the column cannot be converted to numbers.

You can refer to the chapter - DAX Error Reference for details on DAX errors.

DAX Formulas and the Relational Model

As you are aware, in the Data Model of Power Pivot, you can work with multiple tables of data and connect the tables by defining relationships. This will enable you to create interesting DAX formulas that use the correlations of the columns among the related tables for calculations.

When you create a relationship between two tables, you are expected to make sure that the two columns used as keys have values that match, at least for most of the rows, if not completely. In the Power Pivot Data Model, it is possible to have non-matching values in a key column and still create a relationship, because Power Pivot does not enforce referential integrity (look at the next section for details). However, the presence of blank or non-matching values in a key column might affect the results of the DAX formulas and the appearance of PivotTables.

Referential Integrity

Establishing referential integrity involves building a set of rules to preserve the defined relationships between tables when you enter or delete data. If you do not exclusively ensure this, as Power Pivot does not enforce it, you might not get correct results with the DAX formulas created before data changes are made.

If you enforce referential integrity, you can prevent the following pitfalls −

  • Adding rows to a related table when there is no associated row in the primary table (i.e. with matching values in the key columns).

  • Changing data in a primary table that would result in orphan rows in a related table (i.e. rows with a data value in the key column that does not have a matching value in the primary table key column).

  • Deleting rows from a primary table when there are matching data values in the rows of the related table.

Updating the Results of DAX Formulas

DAX formulas are used in calculations involving large data, including data from external data sources. The data can be subjected to changes from time to time as the DAX calculations are meant for live data as well.

The results of DAX formulas need to get updated on two occasions −

  • Data Refresh − When the data is refreshed.

  • Recalculation − When there are changes in the DAX formula.

Understanding Data Refresh vs. Recalculation

Data refresh and recalculation are two separate but related operations.

  • Data refresh is the process of updating the data in the Data Model in your workbook obtaining up-to-date data from external data sources.

  • Recalculation is the process of updating all the columns, tables, and PivotTables in your workbook that contain DAX formulas, to reflect the changes in the underlying data that result from the changes to DAX formulas themselves.

You should not save or publish the workbook until the DAX formulas in it have been recalculated.

Different Ways to Update Data in Data Model

Power Pivot does not automatically detect changes in external data sources.

  • You can refresh data manually from the Power Pivot window at intervals that you can specify.

  • You can schedule an automatic data refresh from external sources, if you have published the workbook to a SharePoint site.

For details on these, refer to the chapter – Updating Data in Data Model.

Recalculation of DAX Formulas

Recalculation of a DAX formula is an important task, because during recalculation, column dependencies are checked and you will be notified if a column has changed, if the data is invalid, or if an error has appeared in a DAX formula that used to work.

Recalculation can affect performance in the following ways −

  • For a calculated column, the result of DAX formula should always be recalculated for the entire column, whenever you change the DAX formula.

  • For a calculated field, the result of DAX formula is not calculated until the calculated field is placed in the context of a PivotTable or a PivotChart. The DAX formula will be recalculated when you change any row or column heading that affects the filters on the data or when you manually refresh the PivotTable.

In DAX, recalculating formulas can be done automatically or manually.

To learn more about recalculation, refer to the chapter – Recalculating DAX Formulas.

Excel DAX - Updating Data in the Data Model

DAX is used for calculations on the data in the Data Model in Excel Power Pivot. DAX enables data modeling and reporting activities to be handled in an effective way. However, this requires updating the data in the Data Model from time to time so as to reflect the current data.

You can import data from an external data source into the Data Model of your workbook by establishing a data connection. You can update the data from the source whenever you choose. This option is handy if you are getting data from relational databases that contain live sales information or data feeds that are updated several times a day.

Different Ways of Updating Data in the Data Model

You can update the data in the Data Model in the following ways −

  • Refreshing data in the Data Model from time to time.
  • Making changes to data sources, such as connection properties.
  • Updating the data in the Data Model after the source data has changed.
  • Filtering the data to selectively load rows from a table in the data source.

Refreshing Data in the Data Model

In addition to getting updated data from an existing source, you will need to refresh data in your workbook whenever you make changes to the schema of the source data. These changes can include adding columns or tables, or changing the rows that are imported.

Note that addition of data, changing data, or editing filters always triggers recalculation of DAX formulas that depend on that data source. Refer to the chapter – Recalculating DAX Formulas for details.

You have two types of data refresh in Data Model −

Manual Refresh

If you choose manual refresh option, you can refresh the data in the Data Model manually at any time. You can refresh all data, which is the default, or you can manually choose the tables and columns to refresh for individual data sources.

Automatic or Scheduled Refresh

If you have published your workbook to a PowerPivot Gallery or SharePoint site that supports PowerPivot, you or the SharePoint administrator can create a schedule for automatically updating the data in the workbook. In such a case, you can schedule unattended data refresh on the server.

Manually Refreshing an Existing Data Source

You can manually refresh your data any time, if you need to update the data from an existing data source or get the recent data for designing new DAX formulas. You can refresh a single table, all tables that share the same data connection or all tables in the Data Model.

If you have imported data from a relational data source, such as SQL Server and Oracle, you can update all the related tables in one operation. The operation of loading new or updated data into the Data Model often triggers recalculation of DAX formulas, both of which might require some time to complete. Hence, you should be aware of the potential impact before you change data sources or refresh the data that is obtained from the data source.

To refresh data for a single table or all tables in a Data Model, do the following −

  • Click the Home tab on the Ribbon in the Power Pivot window.
  • Click Refresh.
  • Click Refresh in the dropdown list for refreshing the selected table.
  • Click Refresh All in the dropdown list for refreshing all the tables.

To refresh data for all tables that use the same connection in a Data Model, do the following −

  • Click the Home tab on the Ribbon in Power Pivot window.
  • Click the Existing Connections in the Get External Data group.

Existing Connections dialog box appears.

  • Select a connection.
  • Click the Refresh button.

Data Refresh dialog box appears and data refresh progress information is displayed as the PowerPivot engine reloads data from the selected table or from all tables from the data source.

There are three possible outcomes −

  • Success − Reports on the number of rows imported into each table.

  • Error − An error can occur if the database is offline, you no longer have permissions. A table or column is deleted or renamed in the source.

  • Cancelled − This means Excel did not issue the refresh request, probably because refresh is disabled on the connection.

Click the Close button.

Changing a Data Source

To change the data in your Data Model, you can edit the connection information or update the definition of the tables and columns used in your Data Model in the Power Pivot window.

You can make the following changes to the existing data sources −

Connections

  • Edit the database name or the server name.
  • Change the name of the source text file, spreadsheet, or data feed.
  • Change the location of the data source.
  • For relational data sources, change the default catalog or initial catalog.
  • Change the authentication method or the credentials used to access the data.
  • Edit advanced properties on the data source.

Tables

  • Add or remove a filter on the data.
  • Change the filter criteria.
  • Add or remove tables.
  • Change the table names.
  • Edit mappings between tables in the data source and tables in the Data Model.
  • Select different columns from the data source.

Columns

  • Change the column names.
  • Add new columns.
  • Delete columns from the Data Model (does not affect the data source).

You can edit the properties of an existing data source in the following ways −

  • You can change the connection information, including the file, feed, or database used as a source, its properties or other provider specific connection options.

  • You can change the table and column mappings and remove references to columns that are no longer used.

  • You can change the tables, views, or columns that you get from the external data source.

Modifying a Connection to an Existing Data Source

You can modify the connection that you have created to an external data source by changing the external data source used by the current connection. However, the procedure to be followed depends on the data source type.

  • Click the Home tab on the Ribbon in the PowerPivot window.
  • Click the Existing Connections in the Get External Data group.

Existing Connections dialog box appears. Select the connection that you want to modify.

Depending on the type of the data source you are changing, the provider might be different. Also the properties that are available may require change. Consider a simple example of a connection to an Excel workbook that contains the data.

  • Click the Edit button. Edit Connection dialog box appears.

  • Click the Browse button to locate another database of the same type (Excel workbook in this example), but with a different name or location.

  • Click the Open button.

The new file will get selected. A message appears stating that you have modified connection information and you need to save and refresh the tables to verify the connection.

  • Click the Save button. You will be back in the Existing Connections dialog box.

  • Click the Refresh button. Data Refresh dialog box appears displaying the data refresh progress. The status of data refresh will be displayed. Refer to the section - Manually Refreshing an Existing Data Source for details.

  • Click Close, once the data refresh is a success.

  • Click Close in the Existing Connections dialog box.

Editing Table and Column Mappings (Bindings)

To edit the column mappings when a data source changes, do the following −

  • Click the tab that contains the table you want to modify in the Power Pivot window.

  • Click the Design tab on the Ribbon.

  • Click the Table Properties.

Edit Table Properties dialog box appears.

You can observe the following −

  • The name of the selected table in the Data Model is displayed in the Table Name box.

  • The name of the corresponding table in the external data source is displayed in the Source Name box.

  • There are two options for column names from – Source and Modal.

  • If the columns are named differently in the data source and in the Data Model, you can toggle between the two sets of column names by selecting these options.

  • Preview of the selected table appears in the dialog box.

You can edit the following −

  • To change the table that is used as a data source, select a different table than the selected one in the Source Name dropdown list.

  • Change the column mappings if needed −

    • To add a column that is present in the source but not in the Data Model, select the checkbox beside the column name. Repeat for all the columns that are to be added. The actual data will be loaded into the Data Model, the next time you refresh.

    • If some columns in the Data Model are no longer available in the current data source, a message appears in the notification area that lists the invalid columns. You do not need to do anything.

  • Click the Save button.

When you save the current set of table properties, you will get a message – Please wait. Then the number of rows retrieved will be displayed.

In the table in the Data Model, any invalid columns are automatically removed and new columns are added.

Changing a Column Name and Data Type

You can change the name of a column in a table in the Data Model as follows −

  • Double-click on the header of the column. The name of the column in the header will get highlighted.

  • Type the new column name, overwriting the old name. Alternatively, you can change the name of a column in a table in the Data Model as follows:

  • Select the column by clicking on its header.

  • Right-click the column.

  • Click Rename Column in the dropdown list.

The name of the column in the header will get highlighted. Type the new column name, overwriting the old name.

As you have learnt, all the values in a column in a table in the Data Model must be of the same data type.

To change the data type of a column, do the following −

  • Select the column that you want to change by clicking its header.

  • Click the Home tab on the Ribbon.

  • Click the controls in the Formatting group to modify the column's data type and format.

Adding / Changing a Filter to a Data Source

You can add a filter to a data source when you import data to restrict the number of rows in the table in the Data Model. Later, you can add more rows or decrease the number of rows in the table in the Data Model by changing the filter that you defined earlier.

Adding a Filter to a Data Source During Import

To add a new filter to a data source during data import, do the following −

  • Click the Home tab on the Ribbon in Power Pivot window.
  • Click one of the data sources in the Get External Data group.

Table Import Wizard dialog box appears.

  • Proceed to the step – Select Tables and Views.
  • Select a table and then click Preview & Filter.

Preview Selected Table dialog box appears.

  • Click the column on which you want to apply filter.
  • Click the down arrow to the right of the column heading.

To add a filter, do one of the following −

  • In the list of column values, select or clear one or more values to filter by and then click OK.

    However, if the number of values is extremely large, individual items might not be shown in the list. Instead, you will see the message - "Too many items to show."

  • Click Number Filters or Text Filters (depending on the data type of the column).

    • Then, click one of the comparison operator commands (such as Equals), or click Custom Filter. In the Custom Filter dialog box, create the filter and then click OK.

Note − If you make a mistake at any stage, click the Clear Row Filters button and start over.

  • Click OK. You will be back to Select Tables and Views page of Table Import Wizard.

As you can observe, in the column – Filter Details, a link Applied Filters appears for the column on which you defined the filter.

You can click the link to view the filter expression that was built by the wizard. But, the syntax for each filter expression depends on the provider and you cannot edit it.

  • Click Finish to import the data with filters applied.
  • Close the Table Import Wizard.

Changing a Filter to an Existing Data Source

After you have imported the data, you might have to update it from time to time, by either adding more rows or by restricting the existing rows in the table. In such a case, you can change the existing filters on the table or add new filters.

  • Click the Home tab on the Ribbon in Power Pivot window.

  • Click the Existing Connections in the Get External Data group. Existing Connections dialog box appears.

  • Click the connection that contains the table on which you have to change the filter.

  • Click the Open button.

You will get into Table Import Wizard dialog box. Repeat the steps in the previous section to filter the columns.

Excel DAX - Recalculating DAX Formulas

Recalculation of a DAX formula is required to reflect changes in the data and changes in the formula itself. However, recalculating a DAX formula involves performance cost.

Even then, to obtain accurate results, recalculation is essential. During recalculation, column dependencies are checked and you will be notified if a column has changed, if the data is invalid or if an error has appeared in a DAX formula that used to work.

Types of Recalculation

You have two options for recalculating DAX formulas −

  • Automatic Recalculation Mode (default)
  • Manual Recalculation Mode

By default, Power Pivot automatically recalculates as required while optimizing the time required for processing. However, you can choose to update calculations manually, if you are working with complex formulas or very large data sets and want to control the timing of updates.

Both automatic and manual modes of recalculating DAX formulas have advantages. However, the recommended way is to use automatic recalculation mode. This way you can keep the Power Pivot data in sync and prevent problems caused by deletion of data, changes in names or data types or missing dependencies.

Recalculating DAX Formulas Automatically

If you choose the default mode of recalculating DAX formulas, i.e. recalculating automatically, any changes to data that would cause the result of any DAX formula to change will trigger recalculation of the entire column that contains the DAX formula.

The following changes always require recalculation of DAX formulas −

  • Values from an external data source have been refreshed.

  • The DAX formula itself is changed.

  • Names of tables or columns that are referenced in the DAX formula have been changed.

  • Relationships between tables have been added, modified or deleted.

  • New calculated fields or calculated columns have been added.

  • Changes have been made to other DAX formulas within the workbook, so columns or calculations that depend on those DAX formulas need to be recalculated.

  • Rows have been inserted or deleted in the table.

  • You applied a filter that requires execution of a query to update the data set. The filter could have been applied either in a DAX formula or as part of a PivotTable or PivotChart.

When to Use Manual Recalculation Mode?

You can use manual recalculation mode until you are ready with all your required DAX formulas in your workbook. This way, you can avoid incurring the cost of computing formula results on the workbook that is still in the draft state.

You can use manual recalculation of DAX formulas in the following conditions −

  • You are designing a DAX formula by using a template and want to change the names of the columns and tables used in the DAX formula before you validate it.

  • You know that some data in the workbook has changed but you are working with a different column that has not changed so you want to postpone a recalculation.

  • You are working in a workbook that has many dependencies and want to defer recalculation till you are sure that all the necessary changes have been made.

But, you should be aware that as long as the workbook is configured to manual recalculation mode, any validation or checking of formulas is not performed. This will result in the following −

  • Any new formulas that you add to the workbook will be flagged as containing an error.

  • No results will appear in the new calculated columns.

Configuring the Workbook for Manual Recalculation

As you have learnt, automatic recalculation is the default mode in the Data Model of any workbook. To configure a workbook for manual recalculation, do the following −

  • Click the Design tab on the Ribbon in the Power Pivot window.
  • Click the Calculation Options in the Calculations group.
  • Click the Manual Calculation Mode in the dropdown list.

Recalculating DAX Formulas Manually

To recalculate the DAX formulas manually, do the following −

  • Click the Design tab on the Ribbon in the Power Pivot window.
  • Click the Calculation Options field in the Calculations group.
  • Click the Calculate Now field in the dropdown list.

Troubleshooting DAX Formula Recalculation

Whenever changes occur in the Data Model of your workbook, Power Pivot performs an analysis of the existing data to determine whether recalculation is required and performs the update in the most efficient way possible.

Power Pivot handles the following, during recalculation of DAX formulas −

  • Dependencies
  • Sequence of recalculation for dependent columns
  • Transactions
  • Recalculation of volatile functions

Dependencies

When a column depends on another column, and the contents of that other column change in any way, all related columns might need to be recalculated.

Power Pivot always performs a complete recalculation for a table, because a complete recalculation is more efficient than checking for changed values. The changes that trigger recalculation might include deleting a column, changing the numeric data type of a column or adding a new column. These changes are considered as major changes. However, seemingly trivial changes, such as changing the name of a column might also trigger recalculation. This is because the names of the columns are used as identifiers in the DAX formulas.

In some cases, Power Pivot may determine that columns can be excluded from recalculation.

Sequence of Recalculation for Dependent Columns

Dependencies are calculated prior to any recalculation. If there are multiple columns that depend on each other, Power Pivot follows the sequence of dependencies. This ensures that the columns are processed in the right order at the maximum speed.

Transactions

Operations that recalculate or refresh data take place as a transaction. This means that if any part of the refresh operation fails, the remaining operations are rolled back. This is to ensure that data is not left in a partially processed state. However, you cannot manage the transactions as you do in a relational database or create checkpoints.

Recalculation of Volatile Functions

DAX functions such as NOW, RAND, or TODAY do not have fixed values and are referred to as volatile functions. If such DAX functions are used in a calculated column, the execution of a query or filtering will usually not cause them to be re-evaluated to avoid performance problems.

The results for these DAX functions are only recalculated when the entire column is recalculated. These situations include refresh from an external data source or manual editing of data that causes re-evaluation of DAX formulas that contain these functions.

However, such functions will always be recalculated if the functions are used in the definition of a Calculated Field.

Excel DAX - Formula Errors

You can get errors when you write DAX formulas with wrong syntax. Calculated fields and calculated columns can contain DAX functions that require a specific type of arguments. Arguments of DAX functions can be tables, columns, or other DAX functions (nested DAX functions). As DAX functions can return tables and columns, care should be taken to check that the right type of arguments are passed to the DAX functions.

DAX formula errors can be either syntax errors or semantic errors. The errors can occur either at design time or at run time.

In this chapter, you will learn about some common DAX errors, their causes, and how to fix those errors.

DAX Error: Calculation Aborted

The following error can occur when attempting to create (design-time) or use (run-time) a calculated field with a DAX time-intelligence function. In each case, a noncontiguous date range is being passed to the time intelligence function.

“DAX Error: CALCULATION ABORTED: MdxScript (instance) (00, 0) Function ‘DATEADD’ only works with contiguous date selections.”

Cause at Run-time

This error can be displayed when a calculated field with a DAX time intelligence function is placed in the VALUES area of a PivotTable and date fields such as the month or the quarter are selected as slicers or filters before selecting a year. For example, if you have data of three years – 2014, 2015, and 2016 and you try to use only the month March without selecting the Year field, then the values are not contiguous data values and you will get an error.

How to Fix the Error at Run-time?

In the above example,

  • First add Year as a slicer or a filter and select a year.

  • Then, add Month or Quarter as a slicer or a filter.

  • Then, select one or more months or quarters to slice or filter on for the year selected.

Cause at Design-time

DAX time intelligence functions require a date column specified for the date argument. The date column must have a contiguous range of dates. This error can be returned, if there is a date value in one or more rows in the date column that is not contiguous with the data values in the previous and successive rows.

If you imported your table containing dates from a data source, remember that many organizations run special processes that scan tables in databases for invalid values and replace those with a particular value. That is, if an invalid date is found, it is assigned a particular date value that may not be contiguous with other data values in the column.

How to Fix This Error at Design-time?

Do the following to fix the error at design time −

  • If your date table is imported from a data source, use Refresh in Power Pivot window to reimport any changes found at the source.

  • Check the values in your date column to make sure they are in a contiguous order. If any value is found not to be in place, it will have to be corrected at the source and the date table will have to be refreshed.

  • Create a separate date table and date column in your Data Model. Specify the new date column as the date argument in the formula causing the error. Date tables are easy to create and add to a Data Model.

DAX Semantic Error - An Example

The following DAX error is a semantic error −

“A function ‘CALCULATE’ has been used in a true-false expression that is used as a table filter expression. This is not allowed.”

Cause

This error can appear when one or more filter expressions cannot be used in context of the calculated field or calculated column expression.

In most of the cases, this error is caused by a filter expression specified as an argument to the DAX CALCULATE function. The CALCULATE function requires filters defined as a Boolean expression or a table expression.

How to Fix Such Errors?

You can fix such errors by using the DAX FILTER function to define filters as a table expression, which can then be used as an argument to the DAX CALCULATE function.

Excel DAX - Time Intelligence

DAX has an important and powerful feature, referred to as Time Intelligence. Time intelligence enables you to write DAX formulas that refer to the time periods for use in the PivotTables.

DAX has 35 time-intelligence functions specifically for aggregating and comparing data over time. However, these DAX functions have some constraints on the data that you need to understand and work with caution to avoid errors.

Why Time Intelligence Makes DAX Powerful?

The time intelligence functions work with data that is constantly changing, depending on the context you select in PivotTables and Power View visualizations. As you are aware, most of the data analysis involves summarization of data over time periods, comparing data values across the time periods, understanding the trends and making decisions based on future projections.

For example, you might want to sum sales amounts for the past month product-wise and compare the totals with those of other months in the fiscal year. This means, you have to use the dates as a way to group and aggregate sales transactions for a particular period in time.

This is where you can observe the power of DAX. You can use DAX time intelligence functions to define calculated fields that help you in analyzing the data over time, without having to change the date selections in the pivot tables. This makes your job easier. Moreover, you can build PivotTables that would not be possible any other way.

Requirements for DAX Time Intelligence Functions

DAX time intelligence functions have certain requirements. If these requirements are not met, you might get errors or they may not work properly. Hence, you can refer to these requirements as rules or constraints as well. Following are certain DAX time intelligence functions requirements/rules/constraints −

  • You need to have a date table in your Data Model.

  • The date table must include a column considered to be the Date column by DAX. You can name the column the way you want, but it should comply with the following conditions: o The date column should contain a contiguous set of dates that covers every day in the time period you are analyzing the data.

    • Every date must exist once and only once in the date column.

    • You cannot skip any dates (For e.g. you cannot skip weekend dates).

  • DAX time intelligence functions work only on a standard calendar and assume the start of the year as January 1 and the end of the year as December 31, with the months in the year and days in each month as of a calendar year.

However, you can customize a standard calendar for different financial years. It is a good practice to verify the above requirements before any time intelligence function is used.

For more details on date tables and their usage in DAX formulas, refer to the tutorial = Data Modeling with DAX in this tutorials library.

DAX Time Intelligence Functions – Categories

DAX Time Intelligence functions can be categorized as follows −

  • DAX functions that return a single date.
  • DAX functions that return a table of dates.
  • DAX functions that evaluate expressions over a time period.

DAX Functions That Return a Single Date

DAX functions in this category return a single date.

There are 10 DAX functions in this category −

Sr.No. DAX Function & Return Value
1

FIRSTDATE (Date_Column)

Returns the first date in the Date_Column in the current context.

2

LASTDATE (Date_Column)

Returns the last date in the Date_Column in the current context.

3

FIRSTNONBLANK (Date_Column, Expression)

Returns the first date where an expression has a non-blank value.

4

LASTNONBLANK (Date_Column, Expression)

Returns the last date where an expression has a non-blank value.

5

STARTOFMONTH (Date_Column)

Returns the first date of a month in the current context.

6

ENDOFMONTH (Date_Column)

Returns the last date of a month in the current context.

7

STARTOFQUARTER (Date_Column)

Returns the first date of a quarter in the current context.

8

ENDOFQUARTER (Date_Column)

Returns the last date of a quarter in the current context.

9

STARTOFYEAR (Date_Column, [YE_Date])

Returns the first date of a year in the current context.

10

ENDOFYEAR (Date_Column, [YE_Date])

Returns the last date of a year in the current context.

DAX Functions That Return a Table of Dates

DAX Functions in this category return a table of dates. These functions will be mostly used as a SetFilter argument to the DAX function - CALCULATE.

There are 16 DAX functions in this category. Eight (8) of these DAX functions are the “previous” and “next” functions.

  • The “previous” and “next” functions start with a date column in the current context and calculate the previous or next day, month, quarter or year.

  • The “previous” functions work backward from the first date in the current context and the “next” functions move forward from the last date in the current context.

  • The “previous” and “next” functions return the resulting dates in the form of a single column table.

Sr.No. DAX Function & Return Value
1

PREVIOUSDAY (Date_Column)

Returns a table that contains a column of all dates representing the day that is previous to the first date in the Date_Column in the current context.

2

NEXTDAY (Date_Column)

Returns a table that contains a column of all dates from the next day, based on the first date specified in the Date_Column in the current context.

3

PREVIOUSMONTH (Date_Column)

Returns a table that contains a column of all dates from the previous month, based on the first date in the Date_Column in the current context.

4

NEXTMONTH (Date_Column)

Returns a table that contains a column of all dates from the next month, based on the first date in the Date_Column in the current context.

5

PREVIOUSQUARTER (Date_Column)

Returns a table that contains a column of all dates from the previous quarter, based on the first date in the Date_Column in the current context.

6

NEXTQUARTER (Date_Column)

Returns a table that contains a column of all dates in the next quarter, based on the first date specified in the Date_Column in the current context.

7

PREVIOUSYEAR (Date_Column, [YE_Date])

Returns a table that contains a column of all dates from the previous year, given the last date in the Date_Column in the current context.

8

NEXTYEAR (Date_Column, [YE_Date])

Returns a table that contains a column of all dates in the next year, based on the first date in the Date_Column in the current context.

Four (4) DAX functions calculate a set of dates in a period. These functions perform the calculations using the last date in the current context.

Sr.No. DAX Function & Return Value
1

DATESMTD (Date_Column)

Returns a table that contains a column of the dates for the month to date, in the current context.

2

DATESQTD (Date_Column)

Returns a table that contains a column of the dates for the quarter to date, in the current context.

3

DATESYTD (Date_Column, [YE_Date])

Returns a table that contains a column of the dates for the year to date, in the current context.

4

SAMEPERIODLASTYEAR (Date_Column)

Returns a table that contains a column of dates shifted one year back in time from the dates in the specified Date_Column, in the current context.

Note− SAMEPERIODLASTYEAR requires that the current context contains a contiguous set of dates.

If the current context is not a contiguous set of dates, then SAMEPERIODLASTYEAR will return an error.

  • Four (4) DAX functions are used to shift from the set of dates that are in the current context to a new set of dates.

    These DAX functions are more powerful than the previous ones.

    • DAX functions – DATEADD, DATESINPERIOD and PARALLELPERIOD shift some number of time intervals from the current context. The interval can be day, month, quarter or year, represented by the key words – DAY, MONTH, QUARTER and YEAR respectively.

      For example:

  • Shift backward by 2 days.

  • Move forward by 5 months.

  • Move forward by one month from today.

  • Go back to same quarter in the last year.

      If the function argument - number of intervals (integer value) is positive, shift is forward and if it is negative, shift is backward.

    • DAX function – DATESBETWEEN calculates the set of dates between the specified start date and the end date.

Sr.No. Fonction DAX et valeur de retour
1

DATEADD (Date_Column, Number_of_Intervals, Interval)

Renvoie une table qui contient une colonne de dates, décalée vers l'avant ou vers l'arrière dans le temps du nombre spécifié d'intervalles à partir des dates dans le contexte actuel.

2

DATESINPERIOD (Date_Column, Start_Date, Number_of_Intervals, Interval)

Renvoie une table contenant une colonne de dates commençant par start_date et se poursuivant pendant le nombre_de_intervalles spécifié.

3

PARALLELPERIOD (Date_Column, Number_of_Intervals, Interval)

Renvoie une table qui contient une colonne de dates qui représente une période parallèle aux dates de la Date_Column spécifiée dans le contexte actuel, avec les dates décalées d'un certain nombre d'intervalles en avant ou en arrière dans le temps.

4

DATESBETWEEN (Date_Column, Start_Date, End_Date)

Renvoie une table qui contient une colonne de dates commençant par start_date et se poursuivant jusqu'à end_date.

Fonctions DAX qui évaluent des expressions sur une période de temps

Les fonctions DAX de cette catégorie évaluent une expression sur une période spécifiée.

Il y a neuf (9) fonctions DAX dans cette catégorie -

  • Trois (3) fonctions DAX de cette catégorie peuvent être utilisées pour évaluer une expression donnée sur une période de temps spécifiée.

Sr.No. Fonction DAX et valeur de retour
1

TOTALMTD (Expression, Date_Column, [SetFilter])

Évalue la valeur de l'expression pour les dates du mois en cours, dans le contexte actuel.

2

TOTALQTD (Expression, Date_Column, [SetFilter])

Évalue la valeur de l'expression pour les dates du trimestre en cours, dans le contexte actuel.

3

TOTALYTD (Expression, Date_Column, [SetFilter], [YE_Date])

Évalue la valeur de l'expression pour les dates de l'année en cours, dans le contexte actuel

  • Six (6) fonctions DAX de cette catégorie peuvent être utilisées pour calculer les soldes d'ouverture et de clôture.

    • Le solde d'ouverture pour toute période est le même que le solde de clôture de la période précédente.

    • Le solde de clôture comprend toutes les données jusqu'à la fin de la période, tandis que le solde d'ouverture ne comprend aucune donnée de la période en cours.

    • Ces fonctions DAX renvoient toujours la valeur d'une expression évaluée à un moment donné.

  • Le moment qui nous intéresse est toujours la dernière valeur de date possible dans une période calendaire.

  • Le solde d'ouverture est basé sur la dernière date de la période précédente, tandis que le solde de clôture est basé sur la dernière date de la période en cours.

  • La période actuelle est toujours déterminée par la dernière date dans le contexte de la date actuelle.

Sr.No. Fonction DAX et valeur de retour
1

OPENINGBALANCEMONTH (Expression, Date_Column, [SetFilter])

Évalue l'expression à la première date du mois dans le contexte actuel.

2

CLOSINGBALANCEMONTH (Expression, Date_Column, [SetFilter])

Évalue l'expression à la dernière date du mois dans le contexte actuel.

3

OPENINGBALANCEQUARTER (Expression, Date_Column, [SetFilter])

Évalue l'expression à la première date du trimestre, dans le contexte actuel.

4

CLOSINGBALANCEQUARTER (Expression, Date_Column, [SetFilter])

Évalue l'expression à la dernière date du trimestre dans le contexte actuel.

5

OPENINGBALANCEYEAR (Expression, Date_Column, [SetFilter], [YE_Date])

Évalue l'expression à la première date de l'année dans le contexte actuel.

6

CLOSINGBALANCEYEAR (Expression, Date_Column, [SetFilter], [YE_Date])

Évalue l'expression à la dernière date de l'année dans le contexte actuel.

DAX a de puissants filter functionsqui sont assez différentes des fonctions Excel. Les fonctions de recherche fonctionnent à l'aide de tables et de relations, comme une base de données. Les fonctions de filtrage vous permettent de manipuler le contexte des données pour créer des calculs dynamiques.

Note- Les fonctions de filtre DAX qui renvoient une table n'ajoutent pas la table au modèle de données. La table résultante est utilisée comme argument dans une autre fonction DAX. Autrement dit, ces fonctions DAX sont utilisées comme fonctions imbriquées avec d'autres fonctions DAX.

Dans la section suivante, vous apprendrez quelles fonctions de filtre DAX vous pouvez utiliser. Pour plus de détails sur ces fonctions, reportez-vous au didacticiel - Fonctions DAX dans cette bibliothèque de didacticiels.

Fonctions de filtre DAX

Voici les fonctions de filtre DAX -

Sr.No. Fonction DAX et à quoi sert la fonction?
1

ADDMISSINGITEMS (<showAllColumn>, [<showAllColumn>] …, <table>, <groupingColumn>, [<groupingColumn>] …, [filterTable] …)

Ajoute des combinaisons d'éléments de plusieurs colonnes à une table si elles n'existent pas déjà. La détermination des combinaisons d'éléments à ajouter est basée sur le référencement des colonnes source qui contiennent toutes les valeurs possibles pour les colonnes.

Pour déterminer les combinaisons d'éléments de différentes colonnes à évaluer -

  • AutoExist est appliqué aux colonnes de la même table.
  • CrossJoin est appliqué sur différentes tables.
2

ALL ( {<table> | <column>, [<column>], [<column>], … })

Renvoie toutes les lignes de la table donnée ou toutes les valeurs des colonnes spécifiées d'une table, en ignorant les filtres qui auraient pu être appliqués.

Cette fonction est utile pour effacer les filtres et créer des calculs sur toutes les lignes d'une table.

3

ALLEXCEPT (<table>, <column>, [<column>], …)

Supprime tous les filtres de contexte de la table à l'exception des filtres qui ont été appliqués aux colonnes spécifiées comme arguments.

Contrairement à TOUTES, vous pouvez utiliser cette fonction lorsque vous souhaitez supprimer les filtres sur de nombreuses colonnes d'une table, mais pas toutes.

4

ALLNOBLANKROW (<table>|<column>)

À partir de la table parente d'une relation, renvoie -

  • toutes les lignes sauf les lignes vides, ou
  • toutes les valeurs distinctes d'une colonne sauf les lignes vides

La fonction ne tient pas compte des filtres de contexte qui pourraient exister.

5

ALLSELECTED ( [<tableName>|<columnName>] )

Supprime les filtres de contexte des colonnes et des lignes de la requête actuelle, tout en conservant tous les autres filtres de contexte ou filtres explicites.

6

CALCULATE (<expression>, [<filter1>, <filter2> …)]

Évalue une expression dans un contexte modifié par les filtres spécifiés.

Renvoie la valeur qui est le résultat de l'expression.

sept

CALCULATETABLE (<expression>, <filter1>, <filter2>, …)

Évalue une expression de table dans un contexte modifié par les filtres donnés.

Renvoie une table de valeurs.

8

CROSSFILTER (<columnName1>, <columnName2>, <direction>)

Spécifie la direction de filtrage croisé à utiliser dans un calcul pour une relation qui existe entre deux colonnes. Ne renvoie aucune valeur.

9

DISTINCT (<column>)

Renvoie une table à une colonne contenant les valeurs distinctes de la colonne spécifiée. En d'autres termes, les valeurs en double sont supprimées et seules les valeurs uniques sont renvoyées.

La colonne résultante est utilisée comme argument dans une autre fonction DAX.

dix

EARLIER (<column>, <number>)

Renvoie la valeur actuelle de la colonne spécifiée dans une passe d'évaluation externe de la colonne mentionnée spécifiée par le nombre.

11

EARLIEST (<column>)

Renvoie la valeur actuelle de la colonne spécifiée dans une passe d'évaluation externe de la colonne spécifiée.

12

FILTER (<table>, <filter>)

Renvoie une table qui contient uniquement les lignes filtrées.

FILTER est utilisé uniquement en tant que fonction incorporée dans d'autres fonctions qui nécessitent une table comme argument.

13

FILTERS (<columnName>)

Renvoie les valeurs qui sont directement appliquées en tant que filtres à columnName.

FILTERS est utilisé uniquement en tant que fonction incorporée dans d'autres fonctions qui nécessitent une table comme argument.

14

HASONEFILTER (<columnName>)

Renvoie TRUE lorsque le nombre de valeurs directement filtrées sur columnName est égal à un. Sinon, renvoie FALSE.

15

HASONEVALUE (<columnName>)

Renvoie TRUE lorsque le contexte de columnName a été filtré jusqu'à une seule valeur distincte. Sinon, renvoie FALSE.

16

ISCROSSFILTERED (<columnName>)

Renvoie TRUE lorsque columnName ou une autre colonne de la même table ou d'une table associée est filtrée.

17

ISFILTERED (<columnName>)

Renvoie TRUE lorsque columnName est filtré directement. S'il n'y a pas de filtre sur la colonne ou si le filtrage se produit parce qu'une colonne différente dans la même table ou dans une table associée est filtrée, la fonction renvoie FALSE.

18

KEEPFILTERS (<expression>)

Modifie la façon dont les filtres sont appliqués lors de l'évaluation d'une fonction CALCULATE ou CALCULATETABLE.

19

RELATED (<column>)

Renvoie une valeur associée d'une autre table.

20

RELATEDTABLE (<tableName>)

Évalue une expression de table dans un contexte modifié par les filtres donnés.

21

SUBSTITUTEWITHINDEX (<table>, <indexColumnName>, <indexColumnTable>, <orderBy_expression>, [<order>])

Renvoie une table qui représente une demi-jointure gauche des deux tables fournies en arguments.

La demi-jointure est effectuée à l'aide de colonnes communes, déterminées par les noms de colonne communs et le type de données commun.

Les colonnes jointes sont remplacées par une seule colonne dans la table renvoyée qui est de type entier et contient un index.

L'index est une référence dans la table de jointure droite selon un ordre de tri spécifié.

22

USERELATIONSHIP ( <columnName1>,<columnName2>)

Spécifie la relation à utiliser dans un calcul spécifique comme celle qui existe entre columnName1 et columnName2.

23

VALUES (<TableNameOrColumnName>)

Renvoie une table à une colonne contenant les valeurs distinctes de la table ou de la colonne spécifiée.

En d'autres termes, les valeurs en double sont supprimées et seules les valeurs uniques sont renvoyées.

Vous avez appris la syntaxe DAX, l'utilisation des opérateurs DAX et des fonctions DAX dans les chapitres précédents. Comme vous le savez, DAX est un langage de formule utilisé pour la modélisation et l'analyse de données.

DAX peut être utilisé dans divers scénarios. Sur la base des scénarios DAX, DAX optimise les performances et produit des résultats précis et efficaces. Dans ce chapitre, vous apprendrez à connaître certains des scénarios DAX.

Effectuer des calculs complexes

Les formules DAX peuvent effectuer des calculs complexes qui impliquent des agrégations personnalisées, un filtrage et l'utilisation de valeurs conditionnelles. Vous pouvez effectuer les opérations suivantes avec DAX

  • Créez des calculs personnalisés pour un tableau croisé dynamique.
  • Appliquez un filtre à une formule.
  • Supprimez les filtres de manière sélective pour créer un rapport dynamique.
  • Utilisez une valeur provenant d'une boucle externe.

Pour plus de détails, reportez-vous au chapitre Scénarios - Exécution de calculs complexes.

Travailler avec du texte et des dates

DAX peut être utilisé dans les scénarios impliquant l'utilisation de texte, l'extraction et la composition de valeurs de date et d'heure ou la création de valeurs basées sur une condition. Vous pouvez effectuer les opérations suivantes avec DAX -

  • Créez une colonne clé par concaténation.
  • Composez une date en fonction des parties de date extraites d'une date de texte.
  • Définissez une date personnalisée.
  • Modifiez les types de données à l'aide d'une formule.
    • Convertissez les nombres réels en nombres entiers.
    • Convertissez des nombres réels, des entiers ou des dates en chaînes.
    • Convertissez les chaînes en nombres réels ou en dates.

Pour plus de détails, reportez-vous au chapitre Scénarios - Travailler avec du texte et des dates.

Valeurs conditionnelles et test des erreurs

Les fonctions DAX permettent de tester des valeurs dans les données et de renvoyer une valeur différente en fonction d'une condition. Les fonctions DAX qui testent les valeurs sont également utiles pour vérifier la plage ou le type de valeurs, afin d'éviter que des erreurs de données inattendues ne rompent les calculs. Vous pouvez effectuer les opérations suivantes avec DAX -

  • Créez une valeur basée sur une condition.
  • Testez les erreurs dans une formule.

Pour plus de détails, reportez-vous au chapitre Scénarios - Valeurs conditionnelles et test des erreurs.

Utiliser Time Intelligence

Vous avez découvert les fonctions d'intelligence temporelle DAX dans le chapitre - Comprendre l'intelligence temporelle DAX.

Les fonctions d'intelligence temporelle DAX incluent des fonctions pour vous aider à récupérer des dates ou des plages de dates à partir de vos données. Vous pouvez ensuite utiliser ces dates ou plages de dates pour calculer des valeurs sur des périodes similaires. Les fonctions d'intelligence temporelle incluent également des fonctions qui fonctionnent avec des intervalles de date standard, pour vous permettre de comparer des valeurs sur des mois, des années ou des trimestres. Vous pouvez également créer une formule DAX qui compare les valeurs pour la première et la dernière date d'une période spécifiée.

Vous pouvez en savoir plus sur les fonctions d'intelligence DAX et ce qu'elles peuvent faire pour:

  • Calculez les ventes cumulées.
  • Comparez les valeurs au fil du temps.
  • Calculez une valeur sur une plage de dates personnalisée.

Pour plus de détails, reportez-vous au chapitre Scénarios - Utilisation de Time Intelligence.

Classement et comparaison des valeurs

Si vous souhaitez afficher uniquement les n premiers éléments d'une colonne ou d'un tableau croisé dynamique, vous disposez des options suivantes:

  • Appliquez un filtre pour n'afficher que les quelques éléments du haut ou du bas.
  • Créez une formule DAX qui classe les valeurs de manière dynamique et appliquez un filtre.

Chacune de ces options a des avantages et des inconvénients.

Pour plus de détails, reportez-vous au chapitre Scénarios - Classement et comparaison des valeurs.

Les formules DAX peuvent effectuer des calculs complexes qui impliquent des agrégations personnalisées, un filtrage et l'utilisation de valeurs conditionnelles. Vous pouvez effectuer les opérations suivantes avec DAX -

  • Créez des calculs personnalisés pour un tableau croisé dynamique.
  • Appliquez un filtre à une formule DAX.
  • Supprimez les filtres de manière sélective pour créer un rapport dynamique.
  • Utilisez une valeur provenant d'une boucle externe.

Création de calculs personnalisés pour un tableau croisé dynamique

Les fonctions DAX CALCULATE et CALCULATETABLE sont puissantes et flexibles. Ils sont utiles pour définir les champs calculés. Ces fonctions DAX vous permettent de modifier le contexte dans lequel le calcul sera effectué. Vous pouvez également personnaliser le type d'agrégation ou d'opération mathématique à effectuer.

Fonction CALCULATE

CALCULER (<expression>, [<filter1>], [<filter2>]…)

La fonction CALCULATE évalue l'expression donnée dans un contexte modifié par zéro ou plusieurs filtres spécifiés.

Si vos données ont été filtrées, la fonction CALCULATE modifie le contexte dans lequel les données sont filtrées et évalue l'expression dans le nouveau contexte que vous spécifiez par les filtres. Cela signifie que tous les filtres existants sur la colonne spécifiée sont supprimés et que le filtre utilisé dans l'argument de filtre est appliqué à la place.

Exemple

Supposons que vous souhaitiez afficher le pourcentage de médailles filtré par sport par nom de pays. Votre calcul doit obtenir la valeur de pourcentage remplaçant le filtre que vous appliquez sur le pays dans le tableau croisé dynamique.

  • Définissez un champ calculé - Pourcentage du nombre de médailles, comme illustré dans la capture d'écran suivante.

Avec cette formule DAX, toutes les lignes de la table Results sont prises en compte dans la fonction CALCULATE avec le filtre contenant la fonction ALL. De cette façon, vous avez le nombre total dans le dénominateur.

Votre tableau croisé dynamique sera comme indiqué dans la capture d'écran suivante.

Dans la capture d'écran ci-dessus, le pays est filtré sur les États-Unis et les 18 premières valeurs sont affichées dans le tableau croisé dynamique. Ensuite, vous pouvez filtrer dynamiquement les valeurs dans le tableau croisé dynamique. Toutefois, les calculs seront corrects par la formule DAX personnalisée que vous avez utilisée.

La fonction CALCULATETABLE prend une table de valeurs et effectue la même action que celle de la fonction CALCULATE.

Filtrage des données dans des formules

Vous pouvez créer des filtres dans les formules DAX, pour sélectionner les valeurs des données source à utiliser dans les calculs. Vous pouvez le faire en définissant une expression de filtre et en l'utilisant avec la table qui est une entrée de la formule DAX.

L'expression de filtre vous permet d'obtenir un sous-ensemble des données source. Le filtre est appliqué dynamiquement chaque fois que vous mettez à jour les résultats de la formule DAX, en fonction du contexte actuel de vos données et vous pouvez être assuré des résultats précis et attendus.

L'expression de filtre contient généralement une fonction de filtre DAX qui renvoie uniquement les lignes sélectionnées de la table, qui peut ensuite être utilisée comme argument pour une autre fonction DAX que vous utilisez pour l'agrégation de données.

Exemple

La capture d'écran suivante montre la définition d'un champ calculé qui donne le nombre de médailles uniquement pour les sports d'été.

Avec ce champ calculé, le tableau croisé dynamique ressemble à celui illustré dans la capture d'écran suivante.

Comme vous pouvez le constater, les valeurs du tableau croisé dynamique sur le côté droit avec le nouveau champ calculé correspondent à celles qui sont dans le tableau croisé dynamique sur le côté gauche avec le filtre sur le champ Saison appliqué explicitement.

Note - Les fonctions de filtre et de valeur DAX renvoient une table, mais ne renvoient jamais la table ou les lignes directement au modèle de données et sont donc toujours incorporées dans une autre fonction DAX.

Pour plus de détails sur ces fonctions DAX, reportez-vous au chapitre - Fonctions de filtre DAX.

Ajouter et supprimer des filtres dynamiquement

Les formules DAX que vous utilisez dans un tableau croisé dynamique peuvent être affectées par le contexte de tableau croisé dynamique. Cependant, vous pouvez modifier le contexte de manière sélective en ajoutant ou en supprimant des filtres. Vous pouvez utiliser les fonctions DAX ALL et ALLEXCEPT pour sélectionner dynamiquement les lignes indépendamment du contexte du tableau croisé dynamique.

En outre, vous pouvez utiliser les fonctions DAX DISTINCT et VALUES pour renvoyer des valeurs distinctes.

Utilisation d'une valeur d'une boucle externe

Vous pouvez utiliser une valeur d'une boucle précédente pour créer un ensemble de calculs associés avec la fonction DAX EARLIER. Cette fonction DAX prend en charge jusqu'à deux niveaux de boucles imbriquées.

DAX peut être utilisé dans les scénarios impliquant l'utilisation de texte, l'extraction et la composition de valeurs de date et d'heure ou la création de valeurs basées sur une condition. Vous pouvez effectuer les opérations suivantes avec DAX -

  • Créez une colonne clé dans une table par concaténation.
  • Composez une date en fonction des parties de date extraites d'une date de texte.
  • Définissez un format de date personnalisé.
  • Modifiez les types de données à l'aide d'une formule.
    • Convertissez les nombres réels en nombres entiers.
    • Convertissez des nombres réels, des entiers ou des dates en chaînes.
    • Convertissez les chaînes en nombres réels ou en dates.

Création d'une colonne clé par concaténation

Le modèle de données dans PowerPivot n'autorise qu'une seule colonne de clé. Il ne prend pas en charge les clés composites que vous pourriez trouver dans les sources de données externes. Par conséquent, si des clés composites existent dans une table de la source de données, vous devez les combiner en une seule colonne de clé pour la table dans le modèle de données.

Vous pouvez utiliser la fonction DAX CONCATENER pour combiner deux colonnes en une seule colonne dans une table du modèle de données. La fonction DAX CONCATENATE joint deux chaînes de texte en une seule chaîne de texte. Les éléments joints peuvent être du texte, des nombres ou des valeurs booléennes représentées sous forme de texte ou d'une combinaison de ces éléments. Vous pouvez également utiliser une référence de colonne si la colonne contient les valeurs appropriées.

= CONCATENATE ([Column1], [Column2])

La fonction DAX CONCATENATE n'accepte que deux arguments. Si l'un des arguments n'est pas de type de données texte, il sera converti en texte. La fonction DAX CONCATENATE renvoie la chaîne concaténée.

Date basée sur les parties de date extraites d'une date texte

Le modèle de données dans Power Pivot prend en charge un type de données datetime pour les valeurs de date et d'heure. Les fonctions DAX qui fonctionnent sur les valeurs de date et / ou d'heure nécessitent le type de données datetime pour les arguments.

Si votre source de données contient des dates d'un format différent, vous devez d'abord extraire les parties de date à l'aide d'une formule DAX et combiner ces parties pour constituer un type de données datetime DAX valide.

Vous pouvez utiliser les fonctions DAX suivantes pour extraire et composer des dates -

DATE - Renvoie la date spécifiée au format datetime.

DATEVALUE - Convertit une date sous forme de texte en une date au format datetime.

TIMEVALUE - Convertit une heure au format texte en une heure au format datetime.

Définition d'un format de date personnalisé

Supposons que les dates de votre source de données ne soient pas représentées par un format standard. Vous pouvez définir un format de date personnalisé pour vous assurer que les valeurs sont gérées correctement. La fonction DAX FORMAT vous permet de convertir une valeur en texte selon le format spécifié.

FORMAT (<value>, <format_string>)

La fonction FORMAT renvoie une chaîne contenant une valeur formatée comme définie par format_string.

Vous pouvez soit utiliser des formats de date et d'heure prédéfinis, soit créer des formats de date et d'heure définis par l'utilisateur pour l'argument format_string de la fonction FORMAT.

Voici les noms de format de date et d'heure prédéfinis. Si vous utilisez des chaînes autres que ces chaînes prédéfinies, elles seront interprétées comme un format de date et d'heure personnalisé.

S. Non. Format_String & Description
1

"General Date"

Affiche une date et / ou une heure. Par exemple, 2/10/2015 10:10:32 AM

2

"Long Date" or "Medium Date"

Affiche une date selon le format de date longue. Par exemple, mercredi 7 mars 2016

3

"Short Date"

Affiche une date au format de date courte. Par exemple, 2/03/2016

4

"Long Time"

Affiche une heure au format longue durée.

Inclut généralement les heures, les minutes et les secondes.

Par exemple, 10:10:32 AM

5

"Medium Time"

Affiche une heure au format 12 heures.

Par exemple, 21h30

6

"Short Time"

Affiche une heure au format 24 heures.

Par exemple, 14:15

Vous pouvez également utiliser les caractères du tableau suivant pour créer des formats de date / heure définis par l'utilisateur.

S. Non. Caractère et description
1

:

Séparateur de temps.

Séparateur de temps. Sépare les heures, les minutes et les secondes lorsque les valeurs d'heure sont formatées.

2

/

Séparateur de date.

Sépare le jour, le mois et l'année de mise en forme des valeurs de date.

3

%

Utilisé pour indiquer que le caractère suivant doit être lu comme un format à une seule lettre sans tenir compte des lettres de fin. Également utilisé pour indiquer qu'un format à une seule lettre est lu comme un format défini par l'utilisateur.

Voici les détails des différents personnages.

  • %d - Affiche le jour sous forme de nombre sans zéro non significatif (par exemple 5).

  • %dd - Affiche le jour sous forme de nombre avec un zéro non significatif (par exemple 05).

  • %ddd - Affiche le jour sous forme d'abréviation (par exemple Soleil).

  • %dddd - Affiche le jour sous forme de nom complet (par exemple dimanche).

  • %M - Affiche le mois sous forme de nombre sans zéro non significatif (par exemple, janvier est représenté par 1).

  • %MM - Affiche le mois sous forme de nombre avec un zéro non significatif (par exemple, janvier est représenté par 01).

  • %MMM - Affiche le mois sous forme d'abréviation (par exemple, janvier est représenté par janvier).

  • %MMMM - Affiche le mois sous forme de nom de mois complet (par exemple, janvier).

  • %gg - Affiche la chaîne période / ère (par exemple AD).

  • %h- Affiche l'heure sous forme de nombre sans zéros non significatifs en utilisant l'horloge sur 12 heures (par exemple 13:15:15). Utilisation%h s'il s'agit du seul caractère de votre format numérique défini par l'utilisateur.

  • %hh - Affiche l'heure sous forme de nombre avec des zéros non significatifs en utilisant l'horloge de 12 heures (par exemple 13:15:15 PM).

  • %H- Affiche l'heure sous forme de nombre sans zéros non significatifs en utilisant l'horloge de 24 heures (par exemple 13:15:15, 1:15:15). Utilisez% H s'il s'agit du seul caractère de votre format numérique défini par l'utilisateur.

  • %HH - Affiche l'heure sous forme de nombre avec des zéros non significatifs en utilisant l'horloge de 24 heures (par exemple 13:15:15, 1:15:15).

  • %m- Affiche les minutes sous forme de nombre sans zéros non significatifs (par exemple 2: 1: 15). Utilisez% m s'il s'agit du seul caractère de votre format numérique défini par l'utilisateur.

  • %mm - Affiche les minutes sous forme de nombre avec des zéros non significatifs (par exemple 2:01:15).

  • %s- Affiche la seconde sous forme de nombre sans zéros non significatifs (par exemple 2: 15: 5). Utilisez% s s'il s'agit du seul caractère de votre format numérique défini par l'utilisateur.

  • %ss - Affiche la seconde sous forme de nombre avec des zéros non significatifs (par exemple 2:15:05).

  • %f- Affiche des fractions de secondes. Pour par exempleff affiche des centièmes de secondes, alors que ffffaffiche dix millièmes de seconde. Vous pouvez utiliser jusqu'à septfsymboles dans votre format défini par l'utilisateur. Utilisation%f s'il s'agit du seul caractère de votre format numérique défini par l'utilisateur.

  • %t- Utilise l'horloge de 12 heures et affiche un A majuscule pour toute heure avant midi; affiche un P majuscule pour toute heure entre midi et 23 h 59. Utilisez% t s'il s'agit du seul caractère de votre format numérique défini par l'utilisateur.

  • %tt- Pour les paramètres régionaux qui utilisent une horloge de 12 heures, affiche un AM majuscule avec une heure avant midi; affiche un PM majuscule avec n'importe quelle heure entre midi et 23 h 59. Pour les paramètres régionaux utilisant une horloge de 24 heures, n'affiche rien.

  • %y- Affiche le numéro de l'année (0-9) sans zéros non significatifs. Utilisation%y s'il s'agit du seul caractère de votre format numérique défini par l'utilisateur.

  • %yy - Affiche l'année au format numérique à deux chiffres avec un zéro non significatif, le cas échéant.

  • %yyy - Affiche l'année au format numérique à quatre chiffres.

  • %yyyy - Affiche l'année au format numérique à quatre chiffres.

  • %z- Affiche le décalage du fuseau horaire sans zéro non significatif (par exemple -8). Utilisation%z s'il s'agit du seul caractère de votre format numérique défini par l'utilisateur.

  • %zz- Affiche le. décalage du fuseau horaire avec un zéro non significatif (par exemple -08)

  • %zzz - Affiche le décalage complet du fuseau horaire (par exemple -08: 00).

Comme vous pouvez le constater, les chaînes de mise en forme sont sensibles à la casse. Un formatage différent peut être obtenu en utilisant un cas différent.

Modification des types de données des sorties de formule DAX

Dans les formules DAX, le type de données de la sortie est déterminé par les colonnes source et vous ne pouvez pas spécifier explicitement le type de données du résultat. Cela est dû au fait que le type de données optimal est déterminé par Power Pivot. Toutefois, vous pouvez utiliser les conversions de type de données implicites effectuées par Power Pivot pour manipuler le type de données de sortie. Sinon, vous pouvez utiliser certaines fonctions DAX pour convertir le type de données de sortie.

Using the Implicit Data Type Conversions

  • Pour convertir une date ou une chaîne numérique en nombre, multipliez par 1,0. Par exemple, = (AUJOURD'HUI () + 5) * 1.0. Cette formule calcule la date actuelle plus 5 jours et convertit le résultat en une valeur entière.

    • Pour convertir une valeur de date, de nombre ou de devise en chaîne, concaténez la valeur avec une chaîne vide. Par exemple, = Aujourd'hui () & ""

Using the DAX Functions for Data Type Conversions

Vous pouvez utiliser les fonctions DAX pour ce qui suit -

  • Conversion de nombres réels en nombres entiers.
  • Conversion de nombres réels, entiers ou dates en chaînes.
  • Conversion de chaînes en nombres réels ou en dates.

Vous apprendrez cela dans les sections suivantes.

Conversion de nombres réels en nombres entiers

Vous pouvez utiliser les fonctions DAX suivantes pour convertir des nombres réels en entiers -

ROUND (<number>, <num_digits>) - Arrondit un nombre au nombre de chiffres spécifié et renvoie un nombre décimal.

CEILING (<number>, <significance>) - Arrondit un nombre vers le haut, à l'entier le plus proche ou au multiple de signification le plus proche et renvoie un nombre décimal.

FLOOR (<number>, <significance>) - Arrondit un nombre vers le bas, vers zéro, au multiple de signification le plus proche et renvoie un nombre décimal.

Conversion de nombres réels, d'entiers ou de dates en chaînes

Vous pouvez utiliser les fonctions DAX suivantes pour convertir des nombres réels, des entiers ou des dates en chaînes -

FIXED (<number>, [<decimals>], [<no_comma>])- Arrondit un nombre et renvoie le résultat sous forme de texte. Le nombre de chiffres à droite de la virgule décimale est de 2 ou le nombre de décimales spécifié. Le résultat est avec des virgules ou éventuellement sans virgule.

FORMAT (<value>, <format_string>) - Convertit une valeur en texte selon le format spécifié.

Vous avez déjà appris à utiliser la fonction Format pour convertir des dates en chaînes.

Conversion de chaînes en nombres réels ou en dates

Vous pouvez utiliser les fonctions DAX suivantes pour convertir des chaînes en nombres réels ou en dates -

VALUE (<text>) - Convertit une chaîne de texte qui représente un nombre en nombre.

DATEVALUE (date_text) - Convertit une date sous forme de texte en une date au format datetime.

TIMEVALUE (time_text) - Convertit une heure au format texte en une heure au format datetime.

Vous pouvez utiliser les fonctions DAX pour tester les valeurs des données qui aboutissent à des valeurs différentes en fonction d'une condition. Par exemple, vous pouvez tester le montant des ventes annuelles et, en fonction du résultat, étiqueter les revendeurs comme Préféré ou Valeur.

Vous pouvez également utiliser les fonctions DAX pour vérifier la plage ou le type de valeurs, afin d'éviter que des erreurs de données inattendues ne rompent les calculs.

Créer une valeur basée sur une condition

Vous pouvez utiliser des conditions IF imbriquées pour tester des valeurs et générer de nouvelles valeurs de manière conditionnelle. Les fonctions DAX suivantes sont utiles pour le traitement conditionnel et les valeurs conditionnelles -

IF (<logical_test>,<value_if_true>, [<value_if_false>])- Vérifie si une condition est remplie. Renvoie une valeur si la condition est TRUE et une autre valeur si la condition est FALSE. Value_if_false est facultatif, et s'il est omis et que la condition est FALSE, la fonction renvoie BLANK ().

OR (<logical1>,<logical2>)- Vérifie si l'un des arguments est TRUE pour renvoyer TRUE. La fonction renvoie FALSE si les deux arguments sont FALSE.

CONCATENATE (<text1>, <text2>)- Joint deux chaînes de texte en une seule chaîne de texte. Les éléments joints peuvent être du texte, des nombres ou des valeurs booléennes représentées sous forme de texte ou d'une combinaison de ces éléments. Vous pouvez également utiliser une référence de colonne, si la colonne contient les valeurs appropriées.

Test des erreurs dans une formule DAX

Dans DAX, vous ne pouvez pas avoir de valeurs valides dans une ligne d'une colonne calculée et de valeurs non valides dans une autre ligne. Autrement dit, s'il y a une erreur dans une partie d'une colonne calculée, la colonne entière est signalée avec une erreur et vous devez corriger la formule DAX pour supprimer les erreurs qui entraînent des valeurs non valides.

Certaines erreurs courantes dans les formules DAX sont:

  • Division par zéro.
  • L'argument d'une fonction est vide tandis que l'argument attendu est une valeur numérique.

Vous pouvez utiliser une combinaison de fonctions logiques et d'information pour tester les erreurs et toujours renvoyer des valeurs valides pour éviter de renvoyer des erreurs dans une colonne calculée. Les fonctions DAX suivantes vous y aident.

ISBLANK (<value>) - Vérifie si une valeur est vide et renvoie TRUE ou FALSE.

IFERROR (value, value_if_error)- Renvoie value_if_error si l'expression du premier argument entraîne une erreur. Sinon, renvoie la valeur de l'expression elle-même.

La valeur de retour de l'expression et value_if_error doivent être du même type de données. Sinon, vous obtiendrez une erreur.

Vous avez découvert la puissante fonction Time Intelligence de DAX dans le chapitre - Comprendre Time Intelligence. Dans ce chapitre, vous apprendrez à utiliser les fonctions de time intelligence DAX dans divers scénarios.

Les fonctions d'intelligence temporelle DAX incluent -

  • Fonctions qui vous aident à récupérer des dates ou des plages de dates à partir de vos données, qui sont utilisées pour calculer des valeurs sur des périodes similaires.

  • Fonctions qui fonctionnent avec des intervalles de dates standard, pour vous permettre de comparer des valeurs sur des mois, des années ou des trimestres.

  • Fonctions qui récupèrent la première et la dernière date d'une période spécifiée.

  • Des fonctions qui vous aident à travailler sur les soldes d'ouverture et de clôture.

Calcul des ventes cumulées

Vous pouvez utiliser les fonctions d'intelligence temporelle DAX pour créer des formules de calcul des ventes cumulées. Les fonctions DAX suivantes peuvent être utilisées pour calculer les soldes de clôture et d'ouverture -

CLOSINGBALANCEMONTH (<expression>,<dates>, [<filter>]) - Évalue l'expression à la dernière date du mois dans le contexte actuel.

OPENINGBALANCEMONTH (<expression>,<dates>, [<filter>]) - Évalue l'expression à la première date du mois dans le contexte actuel.

CLOSINGBALANCEQUARTER (<expression>,<dates>, [<filter>]) - Évalue l'expression à la dernière date du trimestre dans le contexte actuel.

OPENINGBALANCEQUARTER (<expression>,<dates>, [<filter>]) - Evalue l'expression à la première date du trimestre, dans le contexte actuel.

CLOSINGBALANCEYEAR (<expression>,<dates>, [<filter>], [<year_end_date>]) - Évalue l'expression à la dernière date de l'année dans le contexte actuel.

OPENINGBALANCEYEAR (<expression>, <dates>, <filter>], [<year_end_date>]) - Évalue l'expression à la première date de l'année dans le contexte actuel.

Vous pouvez créer les champs calculés suivants pour l'inventaire du produit à un moment spécifié à l'aide des fonctions DAX suivantes:

Month Start Inventory Value: = OPENINGBALANCEMONTH ( 
   SUMX (ProductInventory, ProductInventory[UnitCost]*ProductInventory[UnitsBalance]), DateTime[DateKey]
)

Month End Inventory Value: = CLOSINGBALANCEMONTH ( 
   SUMX (ProductInventory, ProductInventory[UnitCost]*ProductInventory[UnitsBalance]), DateTime[DateKey]
)

Quarter Start Inventory Value: = OPENINGBALANCEQUARTER ( 
   SUMX ProductInventory, (ProductInventory[UnitCost]*ProductInventory[UnitsBalance]), DateTime[DateKey]
)

Quarter End Inventory Value: = CLOSINGBALANCEQUARTER ( 
   SUMX (ProductInventory, ProductInventory[UnitCost]*ProductInventory[UnitsBalance]), DateTime[DateKey]
)

Year Start Inventory Value: = OPENINGBALANCEYEAR ( 
   SUMX (ProductInventory, ProductInventory[UnitCost]*ProductInventory[UnitsBalance]), DateTime[DateKey]
)

Year End Inventory Value: = CLOSINGBALANCEYEAR ( 
   SUMX (ProductInventory, ProductInventory[UnitCost]*ProductInventory[UnitsBalance]), DateTime[DateKey]
)

Comparaison des valeurs sur différentes périodes

Les périodes par défaut prises en charge par DAX sont les mois, les trimestres et les années.

Vous pouvez utiliser les fonctions d'intelligence temporelle DAX suivantes pour comparer les sommes sur différentes périodes.

  • PREVIOUSMONTH (<dates>) - Renvoie un tableau contenant une colonne de toutes les dates du mois précédent, en fonction de la première date de la colonne des dates, dans le contexte actuel.

  • PREVIOUSQUARTER (<dates>) - Renvoie un tableau contenant une colonne de toutes les dates du trimestre précédent, en fonction de la première date de la colonne des dates, dans le contexte actuel.

  • PREVIOUSYEAR (<dates>, <year_end_date>]) - Renvoie un tableau contenant une colonne de toutes les dates de l'année précédente, compte tenu de la dernière date dans la colonne des dates, dans le contexte actuel.

Vous pouvez créer les champs calculés suivants pour calculer la somme des ventes dans la région Ouest aux périodes spécifiées à des fins de comparaison, à l'aide des fonctions DAX -

Previous Month Sales: = CALCULATE ( 
   SUM (WestSales[SalesAmount]), PREVIOUSMONTH (DateTime [DateKey])
)

Previous Quarter Sales: = CALCULATE ( 
   SUM (WestSales[SalesAmount]), PREVIOUSQUARTER (DateTime [DateKey])
)

Previous Year Sales: = CALCULATE ( 
   SUM (WestSales[SalesAmount]), PREVIOUSYEAR (DateTime [DateKey])
)

Comparaison des valeurs sur des périodes parallèles

Vous pouvez utiliser la fonction DAX Time Intelligence PARALLELPERIOD pour comparer les sommes sur une période parallèle à la période spécifiée.

PARALLELPERIOD (<dates>, <number_of_intervals>, <interval>)

Cette fonction DAX renvoie une table qui contient une colonne de dates représentant une période parallèle aux dates de la colonne de dates spécifiée, dans le contexte actuel, les dates étant décalées d'un certain nombre d'intervalles en avant ou en arrière dans le temps.

Vous pouvez créer le champ calculé suivant pour calculer les ventes de l'année précédente dans la région Ouest -

Previous Year Sales: = CALCULATE ( 
   SUM (West_Sales[SalesAmount]), PARALLELPERIOD (DateTime[DateKey],-1,year)
)

Calcul des totaux cumulés

Vous pouvez utiliser les fonctions d'intelligence temporelle DAX suivantes pour calculer les totaux en cours ou les sommes en cours.

  • TOTALMTD (<expression>,<dates>, [<filter>]) - Évalue la valeur de l'expression pour le mois en cours dans le contexte actuel.

  • TOTALQTD (<expression>,<dates>, <filter>]) - Évalue la valeur de l'expression pour les dates du trimestre en cours, dans le contexte actuel.

  • TOTALYTD (<expression>,<dates>, [<filter>], [<year_end_date>]) - Évalue la valeur cumulative de l'expression dans le contexte actuel.

Vous pouvez créer les champs calculés suivants pour calculer la somme cumulée des ventes dans la région Ouest à des périodes spécifiées, à l'aide des fonctions DAX -

Somme cumulée du mois: = TOTALMTD (SUM (West_Sales [SalesAmount]), DateTime [DateKey])

Somme cumulée du trimestre: = TOTALQTD (SUM (WestSales [SalesAmount]), DateTime [DateKey])

Somme cumulée de l'année: = TOTALYTD (SUM (WestSales [SalesAmount]), DateTime [DateKey])

Calcul d'une valeur sur une plage de dates personnalisée

Vous pouvez utiliser les fonctions d'intelligence temporelle DAX pour récupérer un ensemble personnalisé de dates, que vous pouvez utiliser comme entrée d'une fonction DAX qui effectue des calculs, pour créer des agrégats personnalisés sur des périodes.

DATESINPERIOD (<dates>, <start_date>, <number_of_intervals>, <interval>) - Renvoie une table contenant une colonne de dates commençant par start_date et se poursuivant pendant le nombre_de_intervalles spécifié.

DATESBETWEEN (<dates>, <start_date>, ) - Renvoie une table contenant une colonne de dates commençant par start_date et se poursuivant jusqu'à end_date.

DATEADD (<dates>,<number_of_intervals>,<interval>) - Renvoie une table qui contient une colonne de dates, décalée vers l'avant ou vers l'arrière dans le temps du nombre spécifié d'intervalles à partir des dates dans le contexte actuel.

FIRSTDATE (<dates>) - Renvoie la première date dans le contexte actuel pour la colonne de dates spécifiée.

LASTDATE (<dates>) - Renvoie la dernière date dans le contexte actuel pour la colonne de dates spécifiée.

Vous pouvez créer les formules DAX suivantes pour calculer la somme des ventes dans la région Ouest sur une plage de dates spécifiée, à l'aide des fonctions DAX -

  • Formule DAX pour calculer les ventes pour les 15 jours précédant le 17 juillet 2016.

CALCULATE ( 
   SUM (WestSales[SalesAmount]), DATESINPERIOD (DateTime[DateKey], DATE(2016,17,14), -15, day)
)
  • Formule DAX pour créer un champ calculé qui calcule les ventes du premier trimestre 2016.

= CALCULATE (
   SUM (WestSales[SalesAmount]),DATESBETWEEN (DateTime[DateKey], DATE (2016,1,1), DATE (2016,3,31))
)
  • Formule DAX pour créer un champ calculé qui obtient la première date à laquelle une vente a été effectuée dans la région Ouest pour le contexte actuel.

= FIRSTDATE (WestSales [SaleDateKey])
  • Formule DAX pour créer un champ calculé qui obtient la dernière date à laquelle une vente a été effectuée dans la région Ouest pour le contexte actuel.

= LASTDATE (WestSales [SaleDateKey])
  • Formule DAX pour calculer les dates qui sont un an avant les dates dans le contexte actuel.

= DATEADD (DateTime[DateKey],-1,year)

Si vous souhaitez afficher uniquement le haut n nombre d'éléments dans une colonne ou un tableau croisé dynamique, vous avez les deux options suivantes -

  • Vous pouvez sélectionner n nombre de valeurs supérieures dans le tableau croisé dynamique.

  • Vous pouvez créer une formule DAX qui classe les valeurs de manière dynamique, puis utilise les valeurs de classement dans un segment.

Application d'un filtre pour n'afficher que les quelques éléments les plus populaires

Pour sélectionner n nombre de valeurs principales à afficher dans le tableau croisé dynamique, procédez comme suit:

  • Cliquez sur la flèche vers le bas dans l'en-tête des étiquettes de ligne dans le tableau croisé dynamique.
  • Cliquez sur les filtres de valeur dans la liste déroulante, puis sur 10 premiers.

La boîte de dialogue Top 10 Filter (<nom de la colonne>) apparaît.

  • Sous Afficher, sélectionnez ce qui suit dans les cases de gauche à droite.
    • Top
    • 18 (Le nombre de valeurs principales que vous souhaitez afficher. La valeur par défaut est 10.)
    • Items.
    • Dans la zone par, sélectionnez Nombre de médailles.
  • Cliquez sur OK. Les 18 premières valeurs seront affichées dans le tableau croisé dynamique.

Avantages et inconvénients de l'application d'un filtre

Avantages

  • C'est simple et facile à utiliser.
  • Convient aux tables avec un grand nombre de lignes.

Désavantages

  • Le filtre est uniquement à des fins d'affichage.

  • Si les données sous-jacentes au tableau croisé dynamique changent, vous devez actualiser manuellement le tableau croisé dynamique pour voir les modifications.

Création d'une formule DAX qui classe les valeurs de manière dynamique

Vous pouvez créer une colonne calculée à l'aide d'une formule DAX qui contient les valeurs classées. Vous pouvez ensuite utiliser un segment sur la colonne calculée résultante pour sélectionner les valeurs à afficher.

Vous pouvez obtenir une valeur de classement pour une valeur donnée dans une ligne en comptant le nombre de lignes dans la même table ayant une valeur supérieure à celle qui est comparée. Cette méthode renvoie ce qui suit -

  • Une valeur nulle pour la valeur la plus élevée du tableau.

  • Les valeurs égales auront la même valeur de rang. Sin le nombre de valeurs est égal, la valeur suivante après les valeurs égales aura une valeur de rang non consécutive additionnant le nombre n.

Par exemple, si vous avez une table «Ventes» avec des données de ventes, vous pouvez créer une colonne calculée avec les rangs des valeurs du montant des ventes comme suit -

= COUNTROWS (FILTER (Sales,  
   EARLIER (Sales [Sales Amount]) < Sales [Sales Amount])
) + 1

Ensuite, vous pouvez insérer un segment sur la nouvelle colonne calculée et afficher de manière sélective les valeurs par rangs.

Avantages et inconvénients des classements dynamiques

Avantages

  • Le classement se fait dans le tableau et non sur un tableau croisé dynamique. Par conséquent, peut être utilisé dans n'importe quel nombre de tableaux croisés dynamiques.

  • Les formules DAX sont calculées dynamiquement. Par conséquent, vous pouvez toujours être sûr que le classement est correct même si les données sous-jacentes ont changé.

  • Étant donné que la formule DAX est utilisée dans une colonne calculée, vous pouvez utiliser le classement dans un segment.

  • Convient aux tables avec un grand nombre de lignes.

Désavantages

Étant donné que les calculs DAX sont coûteux en calcul, cette méthode peut ne pas convenir aux tables avec un grand nombre de lignes.