はじめに
Qiita Advent Calendar 2021シリーズ2の25日目の担当は、6日目と16日目に引き続きQiita株式会社プロダクトマーケティングGの中泉(@zumi0)が担当します!最終日に投稿させていただき、大変恐縮です。
今回は、RedashとGASを使った話をしようと思います。
弊社ではBIツールにRedashを導入しています。Redashで様々なデータを抽出し日々注視しているのですが、それらのデータが日次など時間を区切った形式で集計できていないものがあったりします。また、非エンジニアがRedashを使ってデータの抽出・可視化が難しく、スプレッドシートを使った方が簡単なことが多いです。
上記の問題を解決するために、RedashとGASを使って毎日自動で更新されるスプレッドシートを作りました。
非エンジニアの方でもできる内容だと思いますので、興味がある方はやってみてください。
Redashとは
Redashは、オープンソースのBIツールです。SQLを書くことで、社内のデータベースからデータを抽出して可視化したり、ダッシュボードを作成することが可能です。
GASとは
Google Apps Script、通称GAS(ガス)は、Googleが提供しているプログラミング言語です。JavaScriptベースで作られているので、JavaScriptがわかっている方は難なくできると思います。
RedashとGASを使って毎日自動で更新されるスプレッドシートを作った話
今回毎日自動で更新されるスプレッドシートを作成するために、以下の手順を踏みました。
- Redashでクエリを作成
- クエリを定期実行されるように設定
- GASでクエリの結果をスプレッドシートに書き込むスクリプトを作成
- スクリプトを定期実行されるように設定
Redashでクエリを作成
まずはじめにRedashでクエリを作成します。
今回は、以下のような結果が返ってくるクエリを作成したと仮定して話を進めたいと思います。
日付 | Qiitaの登録ユーザー数 | Qiitaの記事投稿数 |
---|---|---|
2021/12/25 | X | Y |
クエリを定期実行されるように設定
クエリを作成したら、そのクエリを定期実行されるように設定します。
設定の仕方は、定期実行をしていない場合クエリの画面の左下に「Never」と記載されているので、そこをクリックして設定します。
GASでも定期実行を行うので、GASよりも早い時間を設定しておきましょう。
GASでクエリの結果をスプレッドシートに書き込むスクリプトを作成
Redashの設定が完了したので、次はGASでスクリプトを作成します。
データを書き込みたいスプレッドシートを作成し、タブから拡張機能 > Apps Scriptでスクリプトのエディタ画面を開くことができます。
今回は、Redashの結果を毎回スプレッドシートの最終行に記載するスクリプトを用意します。Redashの結果は、RedashからAPIを利用して取得します。今回はCSV取得していきます。APIを利用するためには、クエリ画面からCSV形式のデータを取得する用のURLを使います。
Redashの結果を毎回スプレッドシートの最終行に記載するスクリプトはこちらです。ヘッダーに関しては、事前に記載しておくようにしてください。
function getData() {
// 書き込むスプレッドシートをidを使って指定
const sheet = SpreadsheetApp.openById('SHEET_ID').getActiveSheet();
// Redashのデータを取得する
const res = UrlFetchApp.fetch('REDASH_API_URL');
const data = Utilities.parseCsv(res.getContentText("UTF-8"));
// スプレッドシートにRedashのデータを書き込む
sheet.getRange(sheet.getLastRow() + 1, 1, 1, data[1].concat().length).setValues([data[1].concat()])
}
スクリプトを定期実行されるように設定
スクリプトを定期実行させるためには、エディタ画面のサイドバーにある時計マークをクリックします。クリックすると右下に「トリガーを追加」が出てくるので、次はそちらをクリックします。
クリックすると定期実行の設定ができるモーダルが表示されるので、そこで設定します。定期実行したい場合は、「イベントのソースを選択」の欄で、「時間主導型」を選択します。そうすると、どのスパンで設定するか選択できるようになるので、自分がやりたいスパンを選択して完了です。
さいごに
今回は、RedashとGASを使って毎日自動で更新されるスプレッドシートを作った流れを紹介させていただきました。非エンジニアの方でもかける内容になっていると思いますので、興味がある方はやってみてください!