ExcelDAX-数式

DAXは、PowerPivotTablesでカスタム計算を作成するための数式言語です。リレーショナルデータを処理し、DAX式で動的集計を実行するように設計されたDAX関数を使用できます。

DAX formulasExcelの数式と非常によく似ています。DAX数式を作成するには、等号を入力し、その後に関数名または式、および必要な値または引数を入力します。

DAX関数とDAX数式

DAX数式には、DAX関数を含めて、その使用法を活用できます。これは、DAX式がDAX関数と重要な点で異なる傾向がある場所です。

  • DAX関数は、常に完全な列またはテーブルを参照します。テーブルまたは列の特定の値のみを使用する場合は、数式にフィルターを追加できます。

  • 行ごとに計算をカスタマイズする場合、Power Pivotには、現在の行の値または関連する値を使用して、コンテキストによって異なる計算を実行できる関数が用意されています。

  • DAXには、単一の値ではなく、結果としてテーブルを返すタイプの関数が含まれています。これらの関数を使用して、他の関数に入力を提供し、テーブルまたは列全体の値を計算できます。

  • 一部のDAX関数はタイムインテリジェンスを提供します。これにより、意味のある日付範囲を使用して計算を作成し、並行期間全体で結果を比較できます。

DAX式の構文を理解する

すべてのDAX式には次の構文があります-

  • 各数式は等号で始まる必要があります。

  • 等号の右側には、関数名を入力または選択するか、式を入力できます。式には、DAX演算子で接続されたテーブル名と列名を含めることができます。

以下はいくつかの有効なDAX式です-

  • [column_Cost] + [column_Tax]
  • =今日()

IntelliSense機能を理解する

DAXは、DAX数式を迅速かつ正確に記述できるようにするIntelliSense機能を提供します。この機能を使用すると、テーブル、列、および関数の名前を完全に入力する必要はありませんが、DAX式を作成するときに、ドロップダウンリストから関連する名前を選択します。

  • 関数名の最初の数文字の入力を開始します。オートコンプリートは、それらの文字で始まる名前で使用可能な関数のリストを表示します。

  • 関数名のいずれかにポインタを置きます。IntelliSenseツールチップが表示され、機能を使用できるようになります。

  • 関数名をクリックします。関数名が数式バーに表示され、構文が表示されます。これにより、引数を選択する際のガイドが表示されます。

  • 必要なテーブル名の最初の文字を入力します。オートコンプリートは、その文字で始まる名前の使用可能なテーブルと列のリストを表示します。

  • Tabキーを押すか、名前をクリックして、オートコンプリートリストの項目を数式に追加します。

  • クリック Fx使用可能な機能のリストを表示するボタン。ドロップダウンリストから関数を選択するには、矢印キーを使用して項目を強調表示し、[OK]をクリックして関数を数式に追加します。

  • 可能なテーブルと列のドロップダウンリストから引数を選択するか、必要な値を入力して、関数に引数を指定します。

この便利なIntelliSense機能の使用を強くお勧めします。

DAX数式はどこで使用しますか?

DAX数式を使用して、計算列と計算フィールドを作成できます。

  • 列を追加してから数式バーに式を入力することにより、計算列でDAX数式を使用できます。これらの数式は、PowerPivotウィンドウで作成します。

  • 計算フィールドでDAX数式を使用できます。これらの式を作成します-

    • [計算フィールド]ダイアログボックスのExcelウィンドウ、または

    • テーブルの計算領域の[パワーピボット]ウィンドウ。

同じ数式が、計算列で使用されているか計算フィールドで使用されているかによって、動作が異なる場合があります。

  • 計算列では、数式は常にテーブル全体の列のすべての行に適用されます。行のコンテキストに応じて、値が変わる可能性があります。

  • ただし、計算フィールドでは、結果の計算はコンテキストに大きく依存します。つまり、ピボットテーブルの設計と行見出しと列見出しの選択は、計算で使用される値に影響します。

DAX式を作成するには、DAXのコンテキストの概念を理解することが重要です。これは、DAXの旅の最初は少し難しいかもしれませんが、一度理解すれば、複雑で動的なデータ分析に必要な効果的なDAX式を書くことができます。詳細については、「DAXコンテキスト」の章を参照してください。

DAX式の作成

IntelliSense機能については前のセクションですでに学習しました。DAX式を作成するときに使用することを忘れないでください。

DAX式を作成するには、次の手順を使用します-

  • 等号を入力します。

  • 等号の右側に、次のように入力します-

    • 関数名またはテーブル名の最初の文字を入力し、ドロップダウンリストから完全な名前を選択します。

    • 関数名を選択した場合は、括弧 '('を入力します。

    • テーブル名を選択した場合は、角かっこ「[」と入力します。列名の最初の文字を入力し、ドロップダウンリストから完全な名前を選択します。

    • 列名を「]」で閉じ、関数名を「)」で閉じます。

    • 式の間にDAX演算子を入力するか、関数の引数を区切るために「、」と入力します。

    • DAX式が完了するまで、手順1〜5を繰り返します。

たとえば、東部地域の総売上高を検索するとします。以下に示すように、DAX式を記述できます。East_Salesはテーブルの名前です。金額はテーブルの列です。

SUM ([East_Sales[Amount])

「DAX構文」の章ですでに説明したように、列名へのすべての参照では、列名とともにテーブル名を使用することをお勧めします。これは、「完全修飾名」と呼ばれます。

DAXの数式は、計算フィールド用か計算列用かによって異なります。詳細については、以下のセクションを参照してください。

計算列のDAX数式の作成

Power Pivotウィンドウで、計算列のDAX数式を作成できます。

  • 計算列を追加するテーブルのタブをクリックします。
  • リボンの[デザイン]タブをクリックします。
  • [追加]をクリックします。
  • 計算列のDAX数式を数式バーに入力します。
= DIVIDE (East_Sales[Amount], East_Sales[Units])

このDAX式は、テーブルEast_Sales −のすべての行に対して次のことを行います。

  • 行の[金額]列の値を、同じ行の[単位]列の値で除算します。

  • 結果を同じ行の新しく追加された列に配置します。

  • テーブル内のすべての行が完了するまで、手順1と2を繰り返します。

上記の式でそれらのユニットが販売される単価の列を追加しました。

  • ご覧のとおり、計算列には計算スペースとストレージスペースも必要です。したがって、必要な場合にのみ計算列を使用してください。可能かつ十分な場合は、計算フィールドを使用してください。

詳細については、「計算列」の章を参照してください。

計算フィールドのDAX式の作成

ExcelウィンドウまたはPowerPivotウィンドウのいずれかで、計算フィールドのDAX数式を作成できます。計算フィールドの場合は、事前に名前を入力する必要があります。

  • Excelウィンドウで計算フィールドのDAX数式を作成するには、[計算フィールド]ダイアログボックスを使用します。

  • Power Pivotウィンドウの計算フィールドのDAX数式を作成するには、関連するテーブルの計算領域のセルをクリックします。CalculatedFieldName:=でDAX式を開始します。

たとえば、East Sales Amount:= SUM([East_Sales [Amount])の合計

Excelウィンドウの[計算フィールド]ダイアログボックスを使用する場合は、数式を保存する前にチェックして、正しい数式を確実に使用するための必須の習慣にすることができます。

これらのオプションの詳細については、「計算フィールド」の章を参照してください。

数式バーを使用したDAX数式の作成

Power Pivotウィンドウには、Excelウィンドウの数式バーに似た数式バーもあります。数式バーを使用すると、オートコンプリート機能を使用して数式の作成と編集が簡単になり、構文エラーを最小限に抑えることができます。

  • テーブルの名前を入力するには、テーブルの名前の入力を開始します。Formula AutoCompleteは、これらの文字で始まる有効なテーブル名を含むドロップダウンリストを提供します。必要に応じて、1文字から始めてさらに文字を入力し、リストを絞り込むことができます。

  • 列の名前を入力するには、選択したテーブルの列名のリストから列を選択できます。テーブル名の右側に角かっこ「[」を入力し、選択したテーブルの列のリストから列を選択します。

オートコンプリートを使用するためのヒント

以下は、オートコンプリートを使用するためのヒントです。

  • 関数と数式をDAX数式にネストできます。このような場合、ネストされた関数を持つ既存の数式の途中で数式オートコンプリートを使用できます。ドロップダウンリストに値を表示するために挿入ポイントの直前のテキストが使用され、挿入ポイントの後のすべてのテキストは変更されません。

  • 定数用に作成した定義済みの名前は、[オートコンプリート]ドロップダウンリストに表示されませんが、入力することはできます。

  • 関数の閉じ括弧は自動的に追加されません。あなたは自分でそれをする必要があります。

  • 各関数が構文的に正しいことを確認する必要があります。

挿入機能機能を理解する

[関数の挿入]ボタンには、次のラベルが付いています。 fx、PowerPivotウィンドウとExcelウィンドウの両方。

  • [パワーピボット]ウィンドウの[関数の挿入]ボタンは、数式バーの左側にあります。

  • Excelウィンドウの[関数の挿入]ボタンは、数式の右側にある[計算フィールド]ダイアログボックスにあります。

あなたがクリックすると fxボタンをクリックすると、[関数の挿入]ダイアログボックスが表示されます。[関数の挿入]ダイアログボックスは、DAX数式に関連するDAX関数を見つける最も簡単な方法です。

[関数の挿入]ダイアログボックスは、カテゴリ別に関数を選択するのに役立ち、各関数の簡単な説明を提供します。

DAX数式での挿入関数の使用

次の計算フィールドを作成するとします-

Medal Count: = COUNTA (]Medal])

次の手順で[関数の挿入]ダイアログボックスを使用できます-

  • 結果テーブルの計算領域をクリックします。
  • 数式バーに次のように入力します-
Medal Count: =
  • [関数の挿入]ボタンをクリックします(fx)。

[関数の挿入]ダイアログボックスが表示されます。

  • 次のスクリーンショットに示すように、[カテゴリの選択]ボックスで[統計]を選択します。

  • 次のスクリーンショットに示すように、[関数の選択]ボックスで[COUNTA]を選択します。

ご覧のとおり、選択したDAX関数の構文と関数の説明が表示されます。これにより、挿入する関数であることを確認できます。

  • [OK]をクリックします。Medal Count:= COUNTA(が数式バーに表示され、関数構文を表示するツールチップも表示されます。

  • [と入力します。これは、列名を入力しようとしていることを意味します。現在のテーブルのすべての列の名前と計算フィールドがドロップダウンリストに表示されます。IntelliSenseを使用して数式を完成させることができます。

  • Mと入力します。ドロップダウンリストに表示される名前は、「M」で始まる名前に限定されます。

  • メダルをクリックします。

  • メダルをダブルクリックします。メダル数:= COUNTA([メダル]が数式バーに表示されます。括弧を閉じます。

  • Enterキーを押します。これで完了です。同じ手順を使用して、計算列を作成することもできます。同じ手順に従って、関数の挿入機能を使用して、Excelウィンドウの[計算フィールド]ダイアログボックスに関数を挿入することもできます。

  • 挿入機能をクリックします(fx)式の右側にあるボタン。

[関数の挿入]ダイアログボックスが表示されます。残りの手順は上記と同じです。

DAX数式で複数の関数を使用する

DAX数式には、最大64個の入れ子関数を含めることができます。ただし、DAX式に非常に多くの入れ子関数が含まれている可能性はほとんどありません。

DAX式に多くの入れ子関数がある場合、次の欠点があります。

  • 式を作成するのは非常に困難です。
  • 式にエラーがある場合、デバッグは非常に困難になります。
  • 数式の評価はそれほど速くはありません。

このような場合、数式を管理しやすい小さな数式に分割し、大きな数式を段階的に作成できます。

標準集計を使用したDAX式の作成

データ分析を実行するときは、集計データに対して計算を実行します。DAX数式で使用できる、SUM、COUNT、MIN、MAX、DISTINCTCOUNTなどのDAX集計関数がいくつかあります。

Power PivotウィンドウのAutoSum機能を使用すると、標準の集計を使用して数式を自動的に作成できます。

  • PowerPivotウィンドウの[結果]タブをクリックします。結果表が表示されます。
  • [メダル]列をクリックします。列全体–メダルが選択されます。
  • リボンの[ホーム]タブをクリックします。
  • [計算]グループの[自動合計]の横にある下向き矢印をクリックします。
  • ドロップダウンリストで[カウント]をクリックします。

ご覧のとおり、計算されたフィールドCount of Medalは、列の下の計算領域–Medalに表示されます。DAX数式は数式バーにも表示されます-

Count of Medal: = COUNTA([Medal])

AutoSum機能が作業を行い、データ集計用の計算フィールドを作成しました。さらに、AutoSumは、DAX関数COUNTの適切なバリアント、つまりCOUNTAを採用しています(DAXにはCOUNT、COUNTA、COUNTAX関数があります)。

注意– AutoSum機能を使用するには、リボンのAutoSumの横にある下矢印をクリックする必要があります。代わりにAutoSum自体をクリックすると、次のようになります。

Sum of Medal: = SUM([Medal])

また、メダルは数値データ列ではなく、列内のテキストを数値に変換できないため、エラーのフラグが立てられます。

あなたは章を参照することができます- DAX Error Reference DAXエラーの詳細については。

DAX式とリレーショナルモデル

ご存知のように、Power Pivotのデータモデルでは、複数のデータテーブルを操作し、関係を定義することでテーブルを接続できます。これにより、関連するテーブル間の列の相関を計算に使用する興味深いDAX数式を作成できます。

2つのテーブル間に関係を作成するときは、キーとして使用される2つの列の値が、完全ではないにしても、少なくともほとんどの行で一致することを確認する必要があります。Power Pivotデータモデルでは、Power Pivotは参照整合性を強制しないため、キー列に一致しない値が含まれていても関係を作成することができます(詳細については次のセクションを参照してください)。ただし、キー列に空白または一致しない値が存在すると、DAX式の結果とピボットテーブルの外観に影響を与える可能性があります。

参照整合性

参照整合性を確立するには、データを入力または削除するときにテーブル間の定義された関係を保持するための一連のルールを構築する必要があります。Power Pivotが強制しないため、これを排他的に保証しない場合、データ変更が行われる前に作成されたDAX式で正しい結果が得られない可能性があります。

参照整合性を適用すると、次の落とし穴を防ぐことができます-

  • プライマリテーブルに関連する行がない場合(つまり、キー列に一致する値がある場合)に関連するテーブルに行を追加します。

  • プライマリテーブルのデータを変更すると、関連テーブルの行が孤立します(つまり、キー列のデータ値がプライマリテーブルのキー列に一致する値を持たない行)。

  • 関連するテーブルの行に一致するデータ値がある場合、プライマリテーブルから行を削除します。