ビジュアル計算の使用 (プレビュー)
Note
ビジュアル計算は現在、プレビュー段階です。
ビジュアル計算は、ビジュアル上に直接定義および実行される DAX 計算です。 ビジュアル計算を使用すると、以前は作成するのが難しかった計算の作成が容易になり、DAX が簡素化され、メンテナンスが容易になり、パフォーマンスが向上します。
Sales Amount の合計を定義するビジュアル計算の例を次に示します。 必要な DAX が単純であることに注目してください。
Running sum = RUNNINGSUM([Sales Amount])
計算は、ビジュアル内の任意のデータ (columns、メジャー、またはその他のビジュアル計算など) を参照できます。 この機能により、セマンティック モデルの複雑さが解消され、DAX の記述プロセスが簡略化されます。 ビジュアル計算を使用して、合計の実行や移動平均などの一般的なビジネス計算を実行できます。
ビジュアル計算は、DAX の他の計算オプションとは異なります。
ビジュアル計算はモデルには格納されず、代わりにビジュアルに格納されます。 つまり、ビジュアル計算は、ビジュアル上の内容のみを参照できます。 モデル内のすべてのものを事前にビジュアルに追加する必要があります。それにより、フィルター コンテキストやモデルの複雑さに関係なく、ビジュアル計算でそれらを参照することができます。
ビジュアル計算は、計算columnsからのコンテキストの単純さと、メジャーからのオンデマンド計算の柔軟性を組み合わせています。
メジャーと比較すると、ビジュアル計算は詳細レベルではなく集計データに基づいて動作するため、多くの場合パフォーマンス上の利点が得られます。 新しいメジャーまたはビジュアル計算によって計算を実行できる場合、多くの場合、後者の方がパフォーマンスが向上します。
ビジュアル計算はビジュアルの一部であるため、ビジュアル構造を参照でき、柔軟性が高まります。
Power BI で計算を追加する方法の詳細な比較については、「Power BI Desktop での計算オプションの使用」を参照してください。
ビジュアル計算を有効にすると、次のことができます。
- ビジュアル計算をレポートに追加する
- 特定のフィールドを非表示にする
- テンプレートを使用してビジュアル計算をすばやく作成する
- ビジュアルの軸を参照して柔軟なビジュアル計算を行う
以降のセクションでは、previous項目で説明した各要素がビジュアル計算でどのように機能するかについて詳しく説明します。
ビジュアル計算を有効にする
2024 年 9 月以前は、ビジュアル計算を使用するには、[オプションと設定]>[オプション]>[プレビュー機能] で有効にする必要がありました。 [ビジュアル計算]、[OK] の順に選びます。 ビジュアル計算は、Power BI Desktop の再起動後に有効になります。
2024 年 9 月以降は、ビジュアル計算が既定で有効になっているため、この手順は不要になりました。 プレビュー段階にある間は、上記の設定を使用して、必要に応じてビジュアル計算を無効にすることができます。
ビジュアル計算を追加する
ビジュアル計算を追加するには、ビジュアルを選択し、リボンの [新しいビジュアル計算] ボタンを選択します。
ビジュアル計算windowが編集モードで開きます。 編集モード画面は、3 つの主要なセクションで構成されています。次の図に示されているように、上から下に次のセクションがあります。
- ビジュアル プレビュー: 操作しているビジュアルが示されます
- 数式バー: ここでビジュアル計算を追加できます
- ビジュアル マトリックス: ビジュアル内のデータが示され、追加したビジュアル計算の結果が表示されます。 ビジュアルに適用するスタイルまたはテーマは、ビジュアル マトリックスには適用されません。
ビジュアル計算を追加するには、数式バーに式を入力します。 たとえば、 Sales Amount と Total Product Cost by Fiscal Year を含むビジュアルでは、次のように入力して各年の利益を計算するビジュアル計算を追加できます。
Profit = [Sales Amount] – [Total Product Cost]
既定では、ビジュアルのほとんどのビジュアル計算は、計算列と同様に行ごとに評価されます。 previous例では、ビジュアル マトリックスの各行に対して、現在の [Sales Amount] と [Total Product Cost] が減算され、その結果が [Profit] 列に返されます。 メジャーのように SUM などの集計関数を追加することはできますが、必要はありません。 実際、メジャーとビジュアル計算式をより簡単に区別できるように、必要がない場合はこのような集計を追加しない方がよいでしょう。
ビジュアル計算を追加すると、それらがビジュアルのフィールドの一覧に表示されます。
さらに、そのビジュアル計算がビジュアルに表示されます。
ビジュアル計算では、多くの既存の DAX 関数を使用できます。 ビジュアル計算に固有の関数も使用できます。 ビジュアル計算はビジュアル マトリックスの範囲内で動作するため、USERELATIONSHIP、RELATED、RELATEDTABLE などのモデル リレーションシップに依存する関数は使用できません。
ビジュアルからフィールドを非表示にする
ビジュアル計算の編集モードでは、モデリング ビューでcolumnsやテーブルを非表示にできるのと同様に、ビジュアルからフィールドを非表示にすることができます。 たとえば、Profit ビジュアル計算のみを表示する場合は、Sales Amount と Total Profit Cost をビューから非表示にすることができます。
フィールドを非表示にしても、ビジュアルまたはビジュアル マトリックスからそれらのフィールドが削除されることはないため、ビジュアル計算では引き続きそれらを参照して作業を続けることができます。 非表示フィールドは、ビジュアル マトリックスでは引き続き表示されますが、結果のビジュアルには表示されません。 非表示フィールドは、ビジュアル計算が機能するために必要な場合にのみ含めることをお勧めします。
テンプレートの使用
ビジュアル計算には、一般的な計算を簡単に作成できるテンプレートが含まれています。 テンプレートを見つけるには、テンプレート ボタンを選び、使用するテンプレートを選びます。
リボンからテンプレート化されたビジュアル計算を作成するには、 [新しいビジュアル計算 ] ボタンの下部をクリックします。
以下のテンプレートが利用可能です:
- 累計。 値の合計を計算し、前の値に現在の値を追加します。 RUNNINGSUM 関数を使います。
- 移動平均。 値の合計をwindowのサイズで割ることで、指定されたwindow内の一連の値の平均を計算します。 MOVINGAVERAGE 関数を使います。
- 親の割合。 親に対する値の割合を計算します。 COLLAPSE 関数を使います。
- 総計の割合。 COLLAPSEALL 関数を使って、すべての値に対する 1 つの値の割合を計算します。
- 子の平均。 子値のセットの平均値を計算します。 EXPAND 関数を使います。
- previousとの比較。 PREVIOUS 関数を使って、値を前の値と比較します。
- nextとの比較。 NEXT 関数を使って、値を後の値と比較します。
- firstとの比較。 FIRST 関数を使用して、値をfirstの値と比較します。
- lastとの比較。 LAST 関数を使用して、値をlastの値と比較します。
テンプレートを選ぶと、数式バーにそのテンプレートが挿入されます。 これらのテンプレートを開始点として使用できます。 テンプレートに頼らずに独自の式を追加することもできます。
Axis
多くの関数には、ビジュアル計算でのみ使用できる省略可能な Axis パラメータがあります。 Axis は、ビジュアル計算がビジュアル マトリックスを走査する方法に影響します。 Axis パラメーターは、既定ではビジュアルのfirstの軸に設定されます。 多くのビジュアルでは、firstの軸は ROWS です。これは、ビジュアル計算がビジュアル マトリックス内の行ごとに上から下へ評価されることを意味します。 次の表に、Axis パラメータの有効な値を示します。
Axis アイコン | Axis 名 | 説明 |
---|---|---|
ROWS | rowsを上から下へ縦に計算します。 | |
COLUMNS | columnsを左から右へ横に計算します。 | |
ROWS COLUMNS | rowsを上から下へ縦に計算し、左から右へ各列で続けていきます。 | |
COLUMNS ROWS | columnsを左から右へ横に計算し、上から下へ各行で続けていきます。 |
Note
作業中のビジュアルで使用可能な軸の値のみを使用できます。 すべてのビジュアルですべての軸が提供されるわけではなく、中には軸が提供されないビジュアルもあります。
Reset
多くの関数には、ビジュアル計算でのみ使用できる省略可能な Reset パラメータがあります。 Reset は、関数がビジュアル マトリックスの走査中にその値を 0 にリセットするか、別のスコープに切り替えるかどうか、およびそのタイミングに影響します。 Reset パラメーターは既定で None に設定されています。つまり、ビジュアル計算がやり直されることはありません。 Reset では、軸に複数のレベルがあることが想定されています。 軸にレベルが 1 つしかない場合は、PARTITIONBY を使用できます。 次の一覧では、 Reset パラメーターの有効な値について説明します。
- NONE: 既定値であり、計算はリセットされません。
- HIGHESTPARENT: 軸の最上位の親の値が変更されたときに計算をリセットします。
- LOWESTPARENT: 軸の最下位の親の値が変更されたときに計算をリセットします。
- 数値軸上のフィールドを参照し、最も高いフィールドは 1 です。
- フィールドがビジュアル上にある限りフィールド参照。
HIGHESTPARENT と LOWESTPARENT を理解するには、複数のレベルに 3 つのフィールド (Year、Quarter、Month) がある軸を考えてください。 HIGHESTPARENT は Year で、最下位の親は Quarter です。 たとえば、次の視覚的計算は同等であり、毎年 0 から始まる Sales Amount の合計を返します。
RUNNINGSUM([Sales Amount], HIGHESTPARENT)
RUNNINGSUM([Sales Amount], 1)
RUNNINGSUM([Sales Amount], [Year])
これに対し、次のビジュアル計算では、1 四半期ごとに 0 から始まる Sales Amount の合計が返されます。
RUNNINGSUM([Sales Amount], LOWESTPARENT)
RUNNINGSUM([Sales Amount], 2)
最後に、このビジュアル計算 リセットされず 、再起動せずに、毎月の Sales Amount 値を previous 値に追加し続けます。
RUNNINGSUM([Sales Amount])
Axis および Reset と ORDERBY および PARTITIONBY
Axis、Reset、ORDERBY、および PARTITIONBY の 4 つの関数は、ペアでまたは一緒に使用して、計算の評価方法に影響を与えることができます。 これらは多くの場合、次の 2 つのペアで一緒に使用されます。
- Axis および Reset
- ORDERBY と PARTITIONBY
Axis と Reset は、視覚化の構造を参照するため、ビジュアル計算で使用できる関数でのみ使用でき、ビジュアル計算でのみ使用できます。 ORDERBY と PARTITIONBY は、計算columns、メジャー、ビジュアル計算で使用できる関数で、フィールドを参照します。 これらは同じ関数を実行しますが、提供される抽象化レベルが異なります。ビジュアル構造を参照する方が、ORDERBY または PARTITIONBY を使用してフィールドを明示的に参照するよりも柔軟性が高くなります。
Reset では、軸に複数のレベルがあることが想定されています。 軸上の 1 つのレベルに 1 つのフィールドしか存在しないか、複数のフィールドがあるため、軸上に複数のレベルがない場合は、PARTITIONBY を使用できます。
どちらのペアを指定しても問題なく機能しますが、Axis を ORDERBY と PARTITIONBY のいずれかまたは両方と一緒に指定することもできます。その場合、ORDERBY と PARTITIONBY に指定された値によって、Axis で指定された値がオーバーライドされます。 Reset を ORDERBY および PARTITIONBY と組み合わせることはできません。
ORDERBY と PARTITIONBY のペアは、フィールドを明示的に指定することによってフィールド参照を固定するものと考えることができます。一方、Axis と Reset はフィールドに依存しません。これらは、構造を参照し、使用されている構造に含まれるフィールドを参照します。
使用できる関数
既存の DAX 関数の多くがビジュアル計算で使用できます。 ビジュアル計算はビジュアル マトリックスの範囲内で動作するため、USERELATIONSHIP、RELATED、RELATEDTABLE などのモデル リレーションシップに依存する関数は使用できません。
ビジュアル計算には、ビジュアル計算に固有の一連の関数も導入されています。 これらの関数の多くは、DAX window関数へのショートカットを使用する方が簡単です。
Note
次の表で説明されているビジュアル計算固有関数のみを使ってください。 他のビジュアル計算固有関数は、現時点では内部的な使用専用なので、使わないでください。 このプレビューの進行に伴う使用可能な関数の更新については、次の表を参照してください。
関数 | 説明 | 例 | ショートカット先 |
---|---|---|---|
COLLAPSE | 計算は、軸の上位レベルで評価されます。 | Percent of parent = DIVIDE([Sales Amount], COLLAPSE([Sales Amount], ROWS)) | 該当なし |
COLLAPSEALL | 計算は、軸の合計レベルで評価されます。 | Percent of grand total = DIVIDE([Sales Amount], COLLAPSEALL([Sales Amount], ROWS)) | 該当なし |
EXPAND | 計算は、軸の下位レベルで評価されます。 | Average of children = EXPAND(AVERAGE([Sales Amount]), ROWS) | 該当なし |
EXPANDALL | 計算は、軸のリーフ レベルで評価されます。 | リーフ レベルの平均 = EXPANDALL(AVERAGE([販売金額]), ROWS) | 該当なし |
FIRST | 軸のfirstの行を参照します。 | ProfitVSFirst = [Profit] – FIRST([Profit]) | INDEX(1) |
ISATLEVEL | 指定した列が現在のレベルに存在するかどうかを報告します。 | IsFiscalYearAtLevel = ISATLEVEL([Fiscal Year]) | 該当なし |
LAST | 軸のlastの行を参照します。 | ProfitVSLast = [Profit] – LAST([Profit]) | INDEX(-1) |
MOVINGAVERAGE | 軸に移動平均を追加します。 | MovingAverageSales = MOVINGAVERAGE([Sales Amount], 2) | WINDOW |
NEXT | 軸のnextの行を参照します。 | ProfitVSNext = [Profit] – NEXT([Profit]) | OFFSET(1) |
PREVIOUS | 軸のpreviousの行を参照します。 | ProfitVSPrevious = [Profit] – PREVIOUS([Profit]) | OFFSET(-1) |
RANGE | 軸のrowsのスライスを参照します。 | AverageSales = AVERAGEX(RANGE(1), [Sales Amount]) | WINDOW |
RUNNINGSUM | 軸に累計を追加します。 | RunningSumSales = RUNNINGSUM([Sales Amount]) | WINDOW |
ビジュアル計算の書式設定
データ型と書式設定オプションを使用して、ビジュアル計算の書式を設定できます。 カスタム ビジュアル レベルの書式指定文字列を設定することもできます。 ビジュアルの書式設定ペインの [全般] セクションにある [データ形式] オプションを使用して、書式を設定します。
考慮事項と制限事項
ビジュアル計算は現在プレビュー段階であり、プレビュー期間中は、次の考慮事項と制限事項に注意する必要があります。
- すべての視覚化タイプがサポートされているわけではありません。 ビジュアル計算の編集モードを使用して、視覚化タイプを変更します。 また、カスタム ビジュアルは、ビジュアル計算や非表示フィールドでテストされていません。
- 次の視覚化タイプとビジュアル プロパティはテストされており、ビジュアル計算や非表示フィールドでは機能しないことが判明しています。
- ツリーマップ
- スライサー
- R ビジュアル
- Python ビジュアル
- 主要なインフルエンサー
- 分解ツリー
- Q & A
- スマート説明
- メトリック
- ページ分割されたレポート
- Power Apps
- Power Automate
- スモール マルチプル
- 散布図の再生軸
- この機能のパフォーマンスは最終製品を表すものではありません。
- コピー/貼り付けやその他のメカニズムを使用してビジュアル計算を再利用することはできません。
- ビジュアル計算でフィルター処理することはできません。
- ビジュアル計算では、同じまたは異なる詳細レベルでそれ自体を参照することはできません。
- ビジュアル計算または非表示フィールドのカスタマイズは使用できません。
- ビジュアル計算または非表示フィールドを使用するレポートで、[Web に公開] 機能を使用することはできません。
- ビジュアルからデータをエクスポートする場合、ビジュアルの計算結果は 基になるデータ エクスポートに含まれません。 非表示フィールドは、 基になるデータをエクスポートする場合を除き、エクスポートには含まれません。
- ビジュアル計算または非表示フィールドを使用するビジュアルでは、"レコードの確認" ドリルスルー機能を使用できません。
- 視覚化計算には条件付き書式設定を適用できません。
- データ カテゴリは、ビジュアル計算では設定できません。
- ビジュアル計算では集計を変更することはできません。
- ビジュアル計算の並べ替え順序を変更することはできません。
- Power BI Embedded は、ビジュアル計算または非表示フィールドを使用するレポートではサポートされていません。
- SQL Server Analysis Services へのライブ接続はサポートされていません。
- フィールド パラメーターは視覚的な計算で使用できますがいくつかの制限があります。
- [データのない項目を表示する] は、ビジュアル計算では使用できません。
- ビジュアル計算ではデータ制限を使用できません。
- ビジュアル計算で動的書式設定文字列を設定したり、フィールドまたはメジャーに動的書式設定文字列としてビジュアル計算を使用したりすることはできません。
- 視覚的な計算で Azure Maps の [パス] オプションを使用することはできません。
Next つの手順
次の記事は、ビジュアル計算を学習して使用する場合に役立ちます。