どうもsusumu_tanakaです。
今年のアドベンティストカレンダーは前半2つ管理系のネタを書いてしまったので、
同じ流れで、セルフサービスBI周りの話でもしようかなと思いましたが、
内容的に変えたほうがいいかと思うので、一旦セルフサービスBIネタは封印します。
また、どこかの機会で書こうかなと思います。
(どんなレポート作成しているとか、公開できればいいのですがね。。さすがに厳しいかな。)
■セルフサービスBI管理ツール①②
https://qiita.com/susumutanaka/items/8d9e1232a7eea5af1c62
https://qiita.com/susumutanaka/items/830e3434b3e45355c860
じゃぁ、何を書こうかなと、ふと考えたのですが、
今年購入した「fitbit sense」のデータでも可視化してみます。
#fitbitデータについて
2種類あるようです。
・個人マイページからのダウンロード
・APIによるデータ取得
今回は前者の「個人マイページからのダウンロード」で行きましょう!
※APIちょいと調べてみたのですが、登録にURLだの色々と厄介そうだったので・・
まずは、ダッシュボードの「データのエクスポート」画面に行きましょう
■データのエクスポート
https://www.fitbit.com/settings/data/export
この画面の「ダウンロード」ボタンからだと、
あまりよい情報が得られないので、『データをリクエスト』からデータを取得しましょう。
※詳細データ、ストレスの情報とかも入っているので、こっちがオススメ!
データをリクエストして、数分後、ダウンロードができる状態になるので、
そこから、圧縮ファイルを回答すると、こんなフォルダ構成になります。
#ストレスデータの可視化
とりあえず、ストレススコアでも可視化してみますかー
fitbit の現在の最上位モデルの「sense」では、ストレスをスコア化してくれてます。
ストレススコア定義自体は、
①脈拍などの「反応スコア」30point
②運動活動の「運動バランススコア」40point
③睡眠パターンスコア 30point
に分類されるようです。
参考ページ:
https://help.fitbit.com/articles/ja/Help_article/2077.htm
とりあえず、ストレスデータを読み込んでみますかー
データ読み込んで、Power Queryで表示するとこんな感じ。
MAX値とか、不要な列は削除。
ラベル表が分かりづらいので、日本語名に変更っと。
ステータスにNO_DATAってありますが、10/4発売日だので、データ的にはないです。
また、睡眠スコアがあるので、Senseを外してうっかり寢っちゃったときにはスコアが取れないようです。
あと、
カレンダーマスタは欠かせないっすよね。
y-komuroさんの永久保存版のカレンダーマスタのページを参考に追加!
https://qiita.com/y-komuro/items/de3e2cb3dea129260079
(y-komuroさん元気かな、FBにもいないし、元気してるかな。)
日付テーブルも入れて、2つのデータでレポート作成してみましょう!
とりあえずは、日付同士をくっつけて、最低限のモデルでこんな感じでしょうか。
レポート作成に関しては、まぁ、さらっとやって、
こんな感じレポートにしてみました。
グラフで凹んでいるところは、うっかり、Senseを外して寝ちゃったときのスコアですorz
#歩数データの可視化してみる
もう一個、歩数でも可視化してみましょうか。
「Physical Activity」フォルダ内のstepsから始まるファイルに格納されている模様。
複数のJsonファイルあるので、フォルダ読み込みして、1つのデータにまとめた方がよさそうですね。
※このあたりは関数作成しますので、応用効きそうなので、覚えておくと良いかも。
(そんな、ちまちますることより、「you、M言語覚えちゃいなよ」と、Power Query忍者から言われそうですがw)
概要として、こんな感じで進めます。
①JSONファイルのリスト作成
②関数作成
③①に関数を反映
#①JSONファイルのリスト作成
JSONファイルのリスト作成手順としては、
まずは、データ取得で「フォルダー」を選択
読み込むとこんな感じになります。
こんな感じでフィルタして、不要なファイルは削除しましょう!
カスタム列の追加で、「fullPath」を作成しましょう!
fullpathのみとして、nameとFolder Pathは削除しちゃいましょう!
これで一旦リストの作成は完了。
#②関数の作成
続いて、②関数の作成を行います。
1個だけパスをコピーして、新規にクエリを作成します。
新しいデータソースで「Jsonファイル」を指定。
で、テーブルに変換されるので、「展開ボタン」改、「調子にのっちゃって、」ボタンをクリック!
※Power BI勉強会でやったら、当時はめっちゃ受けたんですよね(^ω^;)古いかw
とても注意:日付のフォーマットが、US表記(月/日/年)です。
ファイルのオプション設定で『英語(米国)』を設定しましょう。
※これ設定しないと、誤変換されます。
(本記事の後続で日付が2010年となっているのはかなりあとで気づいたためです。
差し替え大変なので・・そのままにしてます。m(_ _)m)
型(日付/時間と数値)を変換しましょう。
このクエリは、関数用のクエリなので、読み込みを無効にしておく。
で、パラメータ「JsonStepPath」を1個作ります。
で、作成したパラメータを「詳細エディター」で置き換えちゃいます。
関数名:FuncStep
関数の出来上がり!
#③①に関数を反映
これを先程作成したJsonファイルのリストに食わせる。
列の追加から「カスタム関数の呼び出しを」をクリック
カスタム関数の呼び出し画面で先程作成した関数:FncStepを指定
で、列に関数が追加されるので、「調子にのっちゃって」ボタンをクリック!
カラムの型の調整と、日付・時間単位で集計してこんな感じで!Power Query完了!
リレーションシップもこんな感じで
あとは適当に、とりあえず、マトリクスに放り込んでみる!
おお歩数との因果関係分かりそうな気がするー。(うそつけー)
はい。以上となります。
如何だったでしょうか?参考になりましたでしょうか?
関数作成とか、通常やらないこともできたので、僕にとっては、とてもよい学びになりました!
#参考(Special Thanks)
Fitbitのpower BI調べたところ、以下動画が参考になったので
(ほぼパクリじゃねぇかという気もしなくないが。。汗
学んだことをアウトプットするのが大切って誰が言ってたのでセーフ)
https://kohera.be/blog/power-bi/how-to-video-visualise-your-fitbit-data-in-power-bi/
ありがとうございました!