はじめに
2022年に登場した Power BI のフィールド パラメーターは、非常に使い勝手がよく、Power BI ユーザーの間でも好評な機能です。
ただ、最近、あるユーザー様からこんな問題があるけど対応方法ありますか?と問合せを受け、いろいろ調査し対応方法を見つけましたので、この記事で解説していきたいと思います。
※フィールド パラメーターについてもっと知りたい方はこちらのサイトが参考になるかと思います
動的にビジュアル変換ができる「フィールドパラメーター」
フィールド パラメータの衝撃
指標別推移の計算(フィールドパラメータ使用)
[Power BI] Field Parameter フィールドパラメーターのTips① メジャー切り替え時の色を固定する
[Power BI] Field Parameter フィールドパラメーターのTips② 選択したメジャーを表示したい
どのような問題が発生?
フィールド パラメーターを使用してビジュアルを作成する際、フィールド パラメーターの項目の軸を使ってビジュアルの並び順を指定しても、軸の項目の切り替えを行うと、その並び順の設定がリセットされてしまいます。
以下、問題の例をあげます。
- 売上金額を、フィールド パラメーター(年度、四半期、月) で切り替えてみる棒グラフのビジュアルを作成
- 既定ではビジュアルの並び順が売上金額の降順になっているので、ビジュアル右上の・・・で並び順を年度の昇順へ変更
- 軸を年度から四半期へ切り替えると・・・
- あれ? 設定したはずのビジュアルの並び順が売上金額の降順に戻ってしまう??
- あれ? 軸を年度に戻しても、設定したはずの年度の昇順になっていない??
設定したはずのビジュアルの並び順の情報が、軸の切り替えを行うたびに失われ、年度/四半期/月を切り替えるたびに毎回並び順をセットしなおさないといけない形になってしまいます。
原因と対応方法
ビジュアルの並べ替えはそのビジュアルに存在する項目のみ有効
原因は、フィールド パラメーターで軸の項目が入れ替わっていくため、ビジュアルで並べ替えを設定していると、切り替わるタイミングでその項目がビジュアルから無くなり、並び替えの情報が失われるため、上のような事象が発生しているものと思われます。
並び替えは「ビジュアルの並び替え」だけではない
Power BI には並び順を設定する方法がいくつかあり、よく使うものとしては、上図で紹介している「ビジュアルの並び替え」となりますが、それ以外に、「列で並び替え」というものがあります。「列で並べ替え」はビジュアル単位ではなく、元のデータの項目そのものに並べ替えを設定する機能になります。
・ビジュアルの並び替え
Power BI レポートでのグラフの並べ替え方法の変更
・列で並び替え
Power BI で 1 つの列をほかの列で並べ替える
ビジュアルにおける並び順の既定値は「列で並べ替え」が設定されていると「列で並べ替え」が優先される
この並び替えですが、「列で並び替え」が設定されている項目を使用すると、ビジュアルの並び替えの既定値は列の並び替えの方が使用されます。(ビジュアルの並べ替えを見ても何も設定されていない状態)
逆に「列で並び替え」を使用していないと、ビジュアルの並び替えが自動で設定されます。
今回の事象としては、項目に「列で並べ替え」を設定していないので、切り替えを行ったときに、グラフに残っている項目である売上金額の並び順が既定値として再設定されたということになります。
対応策の実装
というわけで、対応策として、フィールド パラメーターで使用する 年度、四半期、月に対して、それぞれ「列で並べ替え」を設定していきます。
なお、今回カレンダーテーブルは以下の記事を参考に作っています。(年度、四半期、月 のテキストと並べ替え用の数値がそれぞれ設定されていてとても使い勝手が良いです)
Power BI 勉強帳:日付(カレンダー)テーブル
-
年度に「列で並べ替え」を設定(データ内容を分かりやすくするためデータビューで表示しています)
テーブルの項目を選択 ⇒ 列で並べ替え ⇒ 並べ替えに利用する項目を選択
※並べ替えに利用する項目は数値である必要があり、かつ、1対1の関係である必要があります
<参考> 列や見出しの並び替え順序を指定するには
-
ビジュアルの動作を確認
フィールド パラメーターのスライサーを動かして動作を見ていきます
まとめと注意事項
- 並びの既定値は、列で並び替え > ビジュアルの並び替え
「列で並び替え」を設定している場合は、列の並び替えが既定値になりビジュアルの並び替えは設定されない。手動で後からビジュアルの並び替えを設定することは可能 - 列の並び替えは"別列"の数値で並び替えの設定を行う必要がある
また、並び替えを設定する列と別列は1 対 1 の関係にある必要がある
なお、降順の設定はできないので、降順にしたい場合は別列にマイナスをかけるなどの工夫が必要 - この対応方法では数値タイプのフィールド パラメーターのソート順を維持させることはできない
(なぜならメジャーは列の並び替えを設定できないため)
おわりに
フィールド パラメーターは非常に有用な機能ですが、並び順という落とし穴があるため、利用時に並び順がうまく設定できないという方は、列で並べ替えを設定して、データ自体に並べ替えを設定し実装するよう試してみてください。
関連記事
フィールド パラメーターではないですが、同じような並び順の問題について以下の記事が参考になります
積み上げチャートの並び替え