SaaSアナリティクス:エンゲージメントKPI - DAU / MAU 比率の計算と可視化

SaaS/サブスクリプション型のビジネスの成長のためにはリテンション率を上げる、そしてチャーン率を下げることが重要になりますが、そのためには顧客がいかにプロダクトを頻繁に使っているかを測る指標であるエンゲージメントを上げる必要があります。

このエンゲージメントの指標の出し方はそれぞれの企業によって異なりますが、そのうちの1つにFacebookが使い始めたことで有名になった、DAU/MAU 比率という指標があり、現在も多くの企業で使われています。

今回はこちらの指標を、その計算の仕方と可視化の仕方と一緒に紹介します。

DAU / MAU 比率

DAUとはDaily Active Userの略で、1日単位で何人のユーザーがプロダクトを使ったかという指標です。

MAUはMonthly Active Userの略で、1ヶ月単位で何人のユーザーがプロダクトを使ったかという指標です。

DAU / MAU 比率は、このDAUをMAUで割ったものです。

例えばMAUが100人で、そのうちの全員が毎日プロダクトを使っていたら、DAU / MAU 比率は1、つまり100%になります。逆にみんなが1ヶ月に1回しか使わないようなプロダクト(例えば、月末の給料の支払い処理のサービスなど)だとほぼ毎日のDAU / MAU 比率はゼロに近くなっていきます。

そこで、このDAU / MAU 比率を見ることで、どれだけ多くの人が頻繁にプロダクトを使っているのかが分かるのです。もちろん頻繁に使われているプロダクトのほうが、この先も長く使われるだろうと推測することができます。

使用データ概要

では早速、MAU / DAU比率を計算していきましょう。今回は以下のような1行が時間・顧客ごとのサービスの利用ログを表すデータを使っていきます。

データはこちらからダウンロードできます。

データ項目

  • timestamp(ユーザーがサービスにアクセスした日時)
  • user_id(ユーザーごとに一意なID)

計算の手順

以下の手順でサービス・ログを集計します。

  1. 元データからDAUを集計する
  2. 元データからブランチを作成してMAUを集計する
  3. timestamp_month列を作る
  4. MAUを元データに結合する
  5. DAU / MAU 比率を計算する

DAUを計算する

まずはDAUから計算していきます。「user_id」の列ヘッダーメニューからユーザー数を集計できるように、「一意な値の数(unique)」を選択します。

集計(Summarize)ダイアログが表示されるので、グループ化に「timestamp」列を選択します。

この時、スケールに「年に切捨て」が設定されているので、このままだと1年単位で何人のユーザーがプロダクトを使ったかが集計されてしまいます。

今は1日単位で何人のユーザーがプロダクトを使ったか、つまりはDAUを集計したいので、「グループ化」のスケールで「日に切捨て」を選択します。

DAUが集計できました。

列名が「user_id」のままだと、ややこしいので列名を変更しましょう。列ヘッダーメニューから「列名を変更」を選択します。

「user_id」を「DAU」に変更します。

これで分かりやすくなりました。

MAUを計算する

次はMAUを集計します。元のデータフレームをDAUの集計用に利用したことで、MAUを集計するために必要な「user_id」が消えてしまいました。

そこで「ブランチ」機能を利用してMAUを計算します。

最初のステップを選択し、「ブランチの作成」アイコンをクリックして新しいブランチを作成します。

「MAU」というブランチ名にします。

ブランチが作成され、元のデータフレームの最初のステップと同じ内容のデータフレームが表示されました。

それではMAUを集計していきましょう。DAUを集計したときと同様に「user_id」の列ヘッダーメニューから「一意な値の数(unique)」を選択します。

今回は1ヶ月単位でのユーザーの数を集計をしたいので、「グループ化」に「timestamp」を選択し、スケールに「月に切り捨て」を選択します。

MAUが集計できました。ただ列名が「user_id」のままだと、ややこしいので列名を変更しましょう。列ヘッダーメニューから「列名を変更」を選択します。

「user_id」を「MAU」に変更します。

これで分かりやすくなりました。

「timestamp_month」列をDAUのデータフレームに作る

ただ今はDAUとMAUが別のデータフレームで集計されているので、DAU / MAU 比率が計算できるように1つのデータフレームにDAUとMAUをまとめる必要があります。

そこで2つのデータフレームがJoin(結合)できるようにDAUのデータフレームに「月」で切り捨てされた日付列を作ります。

まずは「DAU」を集計したデータフレームに移動します。

続いて最新のステップに移動します。

最新のステップに移動したら、「timestamp」の列ヘッダーメニューから「丸め処理」 -> 「日付の切り捨て」 -> 「月」を選択します。

計算を作成(Mutate)ダイアログが表示されるので「新しく列を作成」を選択し、列名を「timestamp_month」として、計算を実行します。

これで「MAU」のデータフレームと結合可能な「キー」列が追加できました。

DAUのデータフレームにMAUを結合する

いよいよ「DAU」のデータフレームに「MAU」のデータフレームを結合していきます。

「timestamp_month」の列ヘッダーメニューから「結合(列を追加する / Join)…」を選択します。

結合(列を追加する / Join )ダイアログが表示されるので、「結合先データフレーム」に「MAU」、「キー列」に「timestamp_mon」を選択し、実行します。

MAUが追加されました。

DAU / MAU 比率を計算する

いよいよDAU / MAU 比率の計算です。「DAU」の列ヘッダーメニューから「計算を作成(Mutate)」を選択します。

計算を作成(Mutate)のダイアログが表示されるので、「新しく列を作成」を選択、列名を「Engagement」とし、計算エディタに以下のように入力し、「DAU」を「MAU」で割ります。

DAU / MAU

Engagement(DAU / MAU 比率)が集計できました。

DAU / MAU 比率を可視化する

Engagement(DAU / MAU 比率)が求められたので、チャート・ビューに移動して可視化していきます。

チャートのタイプで「ライン」を選択し、X軸に「timestamp_day」、Y軸に「Engagement」を選択します。

続いてX軸に「timestamp_day」のスケールを「日に切り捨て」に変更します。

これで日毎のDAU / MAU比率が可視化されました。

ダッシュボードでモニターする

さらにこういった定点観測するようなチャートはダッシュボードにまとめて、スケジュール機能を使って更新をしていくと良いかと思います。

  • Exploratoryダッシュボードの紹介 - Link

自分のデータで実際に試してみる

Exploratoryでは30日間の無料トライアルができます。実際に自分達のデータを使って試してみたい方は下記より無料トライアルをご利用ください!

なおExploraotryではSaaSビジネスに役立つ情報を他にもまとめています。ご興味ある方は是非ご参考ください。

詳細はこちらのページにあります。


データサイエンス・ブートキャンプ、11月開催!

データサイエンス、データ分析の手法を一から体系的に学び、現場で使える知識とスキルを身につけていただくためのトレーニング、データサイエンス・ブートキャンプを11月に開催します。

データを使ってビジネスを成長させたい、または問題を解決したいという方は、ぜひこの機会に参加をご検討ください!

詳細はこちらのページにあります。