LoginSignup
0

More than 1 year has passed since last update.

posted at

updated at

Organization

BoxのデータをBigQueryに自動同期し、Googleデータポータル(旧Data Studio)で可視化する

概要

Boxはメンバー間でファイルやフォルダを共有したり、ファイルを簡単に追加、移動、編集したりすることができます。
Boxにアップロードされたデータを分析する際、更新されるたびにデータを転送して最新の状態に保つのには手間がかかります。そこで今回は、troccoという分析基盤向けデータ統合サービスを使い、Boxのデータ取得自動化+DWH(データウェアハウス)への統合+可視化までやってみようと思います。

今回、データの転送手段として採用したtroccoは、Boxの他にも、様々な広告・CRM・DBなどのデータソースにも対応しています。
troccoの使い方まとめ(CRM・広告・データベース他)
boxtobigquery.png

ゴール

下のようなBoxのデータを
boxデータ.png

データポータルで可視化します(作成後は自動で最新値に更新することも可能です)
データ可視化.png

こんな人におすすめ

・BoxのデータをBigQueryに自動的に蓄積させたい
・Boxのデータをうまく活用して分析をしたいが、データの転送作業に苦戦している
・さまざまなデータの分析に時間の浪費を感じている

1. troccoでBox→Google BigQueryの転送自動化

1-0. 事前準備

データの転送のためにはtroccoのアカウント・Googleアカウントが必要です。

無料トライアルを実施しているので、事前に申し込み・登録しておいてください!
https://trocco.io/lp/index.html
(申込の際に、この記事を見た旨を記載して頂ければご案内がスムーズに行えます)

Googleアカウントに関しては、Google BigQueryとGoogleデータポータルは同じアカウントで運用したほうが接続が簡単だと思います。

1-1. 転送元・転送先を決定

troccoにアクセスして、ダッシュボードから「転送設定を作成」のボタンを押します。
ダッシュボード.png

転送元に「Box」を指定し、転送先に「Google BigQuery」を選択して転送設定作成ボタンを押します。
boxbigquery選択.png

すると、設定画面になるので、必要な情報を入力していきます。

1-2. Boxとの連携設定

あとで見たときに自分で分かるように転送設定の名前とメモを入力します。
①概要設定.png

次に「転送元Boxの設定」内の「接続情報を追加」ボタンを押します。
box設定.png

別のタブでBoxの接続情報の新規作成画面が開きます。
接続情報を作成するためにJSONファイルを取得する必要があります。
box接続情報.png

JSONファイルの取得方法は以下の通りです。
https://trocco.zendesk.com/hc/ja/articles/900004862986

1.Boxの開発者コンソールにログインし、マイアプリより「アプリの新規作成」を押してください。
2.カスタムアプリを作成してください。また、このとき「サーバ認証による認証」を選択頂くようにお願いします。
3.カスタムアプリ作成後に「構成」タブに移動し「公開キーの追加と管理」より「公開キー」を追加してください。
4.3より取得したJSONファイルを「カスタムアプリ設定ファイル」に登録してください。

問題がなければ保存します。再度転送設定画面に戻り、接続情報の「接続情報を読み込む」ボタンを押すと、先ほど作成した接続情報が選択できるようになります。
sample追加.png

1-3. Boxからのデータ取得設定

次に、取得するデータの指定を行います。

・フォルダーID
Boxの管理画面より該当のフォルダーに遷移し、URLからフォルダーIDを取得してください。

・パスプレフィックス
取得対象のファイル名のパスプレフィックスを指定してください。(現状ですと、第1階層のファイルデータのみ取得可能です)

・入力ファイル形式
入力ファイル形式を指定してください。

box情報追加.png

1-4. 転送先Google BigQueryの設定

転送元と同様に設定していきます。Google BigQueryに関してはGoogleアカウントとの連携が必要です。(事前に転送先となるデータセットとテーブルを作成しておいてください。)
Googleアカウント連携.png
BigQuery接続情報作成.png

転送先とするデータセット名、テーブルを設定します。
bigquery接続情報.png

これで入力は完了です。接続状況を確認し問題がなければ、「次のステップへ」をクリックし確認作業に進みましょう。

1-5. データのプレビュー

少し待つと、転送元のデータがプレビューされます。ここではBoxから取り込んだデータが表示されています。
スキーマプレビュー.png

ここで、BigQueryの命名規則に合わせてカラム名の変更を行います。BigQueryではカラム名に"."を使うことができないので、sepal.length, sepal.width, petal.length, petal.widthの"."を"_"に変更します。

カラム名変更.png

カラム名の変更を行ったら「変更をプレビュー」を選択します。

変更の確認.png

カラム名の変更を確認できたので、設定を完了します。
転送設定の一覧から作成した設定を選び「スケジュール・通知設定」に進みます。

1-6. スケジュール・通知設定

「スケジュール・トリガー設定」タブを開きます。

スケジュール.png

「スケジュールを追加」ボタンを押すと、以下の画像のような入力欄が出てきます。ここで実行スケジュールを設定することで、転送を定期的に実行し自動化することが出来ます。
時間設定.png

1-7. データ転送ジョブの実行

設定は以上です。最後に、手動で転送ジョブを実行し、Google BigQueryにデータを送ります。
手動で実行する場合はジョブ詳細画面の「実行」ボタンを押します。
実行.png

これで転送は完了です!

2. Google BigQueryの設定

特に設定することはありません。設定で選択したテーブルにデータが転送されているので、今すぐに分析・可視化を行うことが出来ます。
データがきちんと送られているかをプレビューで確認してみます。
bigqeury転送確認.png

転送されていることが確認できました!

3. Googleデータポータルで可視化

それでは、これらのデータをGoogleデータポータルで可視化していきます。

まずはGoogle BigQueryとGoogleデータポータルの接続設定を行います。
Googleデータポータルを開いて、新規のレポートを作成します。
Qiitaテスト.png

「データを追加」のボタンを押し、データ元の選択肢からGoogle BigQueryを選択します。
BigQuery選択.png

転送に使用したプロジェクト、データセット、表(テーブル)を選択し、追加します。
データ表化.png

データベースに接続できたら、使用可能な項目を利用し、必要な情報を表示させることができます。
今回はそれぞれのデータがどのように分布をしているかを知りたいので散布図を用いることにします。

転送.png

「グラフ>散布図」を選択した際に、ディメンション、指標X、指標Yを項目から選択する必要があります。
ディメンションは散布図にプロットするデータを選択することができ、指標X、指標Yは散布図においてそれぞれ、横軸、縦軸に該当します。
まず、ディメンションにpetal_length、指標Xにpetal_length、指標Yにpetal_widthを選択します。
項目指定.png

同様に指標を入れ変えて五つの散布図を加え、レイアウトを調整します。

データ可視化.png

まとめ

いかがでしたでしょうか。troccoを使うと、Boxのデータでも自動でGoogle BigQueryにまとめていくことができるほか、100万規模の大きなデータからそうではない小さなデータまで複雑なコーディングをせずtroccoの画面上の設定のみでデータの転送が可能になります。
実際に弊社サービスのtroccoにおいても、マーケティングKPI等をこのような流れで収集・分析しています。
ぜひ広告データ分析の際にはご活用ください。
https://trocco.io/lp/index.html

実際に試してみたい場合は、無料トライアルを実施しているので、この機会にぜひ一度お試しください。(申込時に、この記事を見た旨を記載して頂ければスムーズにご案内することができます)

その他にも広告やデータベースなど、様々な分析データをETL・転送した事例をまとめました。
troccoの使い方まとめ(CRM・広告・データベース他)

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
What you can do with signing up
0