【Tableau】ダッシュボード内のシートを別のシートに表示切替する方法
1.はじめに
本記事では、ダッシュボードに表示しているシートを別のシートに表示切替をする方法を記載します。この方法は職場のチームメンバーから教えていただいたものです。その内容を自分で試してみたので、本記事にやり方を残します。
2.概要
今回説明用につくったダッシュボードは2つのシートが表示されており、下のシートの表示を切替可能とします。切替はダッシュボードの右側のパラメーター(画面では、単一の値のリスト)を選択することで行えます。
売上シート と【 利益の線グラフ 】 | 売上シート と【 利益の棒グラフ 】 |
---|---|
3.つくりかた
今回のダッシュボードのデータソースは「サンプル - スーパーストア.xls」を用います。ダッシュボードの上のシートは売上、下のシートは利益を表示します。シート数は全部で3つで、売上シートを1つ、利益のシートは線グラフと棒グラフの2つを用意します。ダッシュボード内の利益の棒グラフと線グラフの表示を切り替えられるようにします。作成時のポイントは表示切替するシートは別途データソースを用意する必要があるという点です。
①データソースを設定する
まずはデータソース設定をします。今回の例では3シートともに「サンプル - スーパーストア.xls」の注文を用います。そのため、元のダッシュボード(今回だと上の売上シート)に使うデータソースに加えて、切り替えるシート用のデータソースをそれぞれ用意します。よって、今回計3つのデータソースを用意します。
②シートを用意する
以下の3シートを用意しました。注意点としては、用意したデータソース3つをそれぞれ利用してシートを作成してください。
売上シート(データソース:注文 (サンプル - スーパーストア))
利益の線グラフ(データソース:注文 (サンプル - スーパーストア) (2))
利益の棒グラフ(データソース:注文 (サンプル - スーパーストア) (3))
③パラメーターを作成する
次に、利益のシートを切り替えるパラメーターを作ります。キャプチャのような具合に設定します。パラメーターの設定をする際に、処理スピード向上のためデータ型は”整数”とし、値のリストの「値」に整数を入力してください。データ型を文字列などにしても作成は可能ですが、一番処理スピードが早いのは整数となります。
④計算フィールドを作成する
今回は2つの計算フィールドを作成します。1つ目は2つ用意した利益のシート(正確にはデータソース)をそれぞれ識別するための計算フィールド、2つ目はその識別したシートの表示/非表示を実現するための計算フィールドとなります。
④-1 2つの利益のシートをそれぞれ識別するための計算フィールド
利益の線グラフのシートを開きます。次に、データソースの選択が利益の線グラフ用に用意したデータソースとなっていることを確認します。キャプチャの例では、データソースが「注文 (サンプル - スーパーストア) (2)」が利益の線グラフ用のデータソースとなります。
対象のデータソース(例:注文 (サンプル - スーパーストア) (2))に計算フィールドを追加します。名前は説明上わかりやすい名前としていますので、ご自身がわかりやすい名前としてください。
計算フィールド名:シート切替用の識別フィールド
計算フィールドの式:1
利益の棒グラフも同様の計算フィールドを作成します。ほぼ同じ内容ですが、異なる点は計算フィールドの式を 2 とする点です。手順は、先ほどと同じく利益の棒グラフのシートを開いて、利益の棒グラフ用のデータセットが選択されていることを確認してください。そして、計算フィールドを作成します。
計算フィールド名:シート切替用の識別フィールド
計算フィールドの式:2 ←注意
④-2 識別したシートの表示/非表示を実現するための計算フィールドを作成する
④-1で計算フィールドを追加した2つのデータソースに対して、以下の計算フィールドをそれぞれ作成します。このとき、名称と式の内容は同じとなります。
計算フィールド名:シート切替用の判定フィールド
[シート切替] = [シート切替用の識別フィールド]
④-3 フィルターを設定して切替機能を実現する
この作業は利益2シート(線グラフ、棒グラフ)の両方で実施します。利益の線グラフのシートを開き、パラメーターのシート切替を右クリックして「パラメータの表示」をします。表示の仕方は好みですが、今回は「単一の値のリスト」とします。そして、パラメーターの設定値が現在表示しているシートになっていることを確認してください(今回は「利益の線グラフ」)。もしも、異なる場合はパラメーターをクリックして変更してください。そうすると以下の画面のようになります。
次に、フィルターにシート切替用の判定フィールドを設定してください。フィルター設定では、リストからの選択の真にクリックしてOKをクリックしてください。値が偽になっている場合は、パラメーターの設定が開いているシートになっていないため、フィルター設定画面を一度閉じてパラメーターの指定値を変更してください。ここまでの作業を利益の棒グラフのシートでも行ってください。
この設定で、パラメーターで選択したシートは表示され、選択されていないシートは非表示となります。非表示になる理由は、設定したフィルターにより表示対象のデータが0件(0行)となったからです。表示対象データが0件のためグラフが表示されなくなります。
パラメーターで「利益の線グラフ」を選択したときの利益のシートの状態
利益の線グラフ | 利益の棒グラフ |
---|---|
⑤ダッシュボードを作成する
新しいダッシュボードのシートを追加します。売上のシート、パラメーターの「シート切替」、利益の線グラフを配置します。
次に、浮動を選択して、「利益の棒グラフ」をダッシュボードの上にドラッグアンドドロップして、シートの範囲を「利益の線グラフ」とピッタリ合わせます。そうすると、キャプチャの黄緑の枠のようにタイトルの"利益の"と"グラフ"という文字が揃います(線と棒は重なった状態となります)。
これで完成ですが、タイトルの表示が重なったままなので今回はタイトルを非表示にします。利益の線グラフは重ねた時に下にあってクリックが難しいので、レイアウトから設定を変更します。レイアウトに表示されている各シートの名称を右クリックしてメニューのタイトルをクリックしてください。そうすると、ダッシュボード上のタイトルが非表示となります。
完成したダッシュボードが以下となります。左の画像は、パラメーターで「利益の線グラフ」が選択されていて、ダッシュボードの下のシートが線グラフとなっています(右側の棒グラフも同様です)。
売上シート と【 利益の線グラフ 】 | 売上シート と【 利益の棒グラフ 】 |
---|---|
⑥ダッシュボードの拡張を考える
つくりかたの最後に、このダッシュボードの拡張を考えます。
【利益の線グラフと同じタイミングで表示するシートを増やしたい場合】
利益の線グラフ用のデータソースを使って新しいシートをつくれば、利益の線グラフと同じタイミングで表示/非表示できます。別のデータソースの場合は、同じやり方でシートとデータソースの設定(手順の④)をしてダッシュボードに配置してください。その際に、「シート切替用の識別フィールド」に設定する値を利益の線グラフと同じ値(整数の1)に揃えればOKです。
【売上シートも線グラフと棒グラフの2種類設ける場合】
売上の線グラフと棒グラフで利用するデータソースを利益の線グラフと棒グラフのデータソースに変更すれば設定完了です(データソースの置換を利用する)。その場合は、データソースは2種類だけで済みます。売上シートの様に、常にダッシュボードに表示する用のデータソースが不要となるからです。
【切替の種類を増やす場合】
例えば、2種類から3種類に増やすのであれば、パラメーターの「シート切替」の値のリストに 3 を追加し、そのパラメーターを選択した時に表示したいシートのデータソースのシート切替用の識別フィールドの値も 3 に設定してください。4つ以上に増やす場合も同様です。
4.最後に
ここまで読んで下さった方、ありがとうございます。少しでもどなたかのViz作成に役立てば幸いです。今回の事例は、データソースの対象行が0行のときにグラフの表示が無くなることと、ダッシュボードの浮動を利用したTipsとなります。Vizの参照者のいくつかの問いの答えを用意するために、今回のようなシート切替の方法も選択肢の1つとして持っていると良いかと思います。もしも、本記事が参考になったという方がいらっしゃいましたら、LGTM(Looks Good To Me!)のクリックをお願いいたします(感謝、そして、歓喜。。。次への励みになります)。
Author And Source
この問題について(【Tableau】ダッシュボード内のシートを別のシートに表示切替する方法), 我々は、より多くの情報をここで見つけました https://qiita.com/sho_szk_/items/9b8e2a8cb5f4faf1a3fe著者帰属:元の著者の情報は、元のURLに含まれています。著作権は原作者に属する。
Content is automatically searched and collected through network algorithms . If there is a violation . Please contact us . We will adjust (correct author information ,or delete content ) as soon as possible .