#1. はじめに
SwitchBot温湿度計は安価で手軽に温湿度の記録ができる非常に便利なデバイスだ。
しかし、1つだけ難点がある。絶対湿度の表示と記録ができないのだ。絶対湿度をウォッチする重要性は松尾設計室の松尾和也氏の記事をはじめ、いろいろなところで指摘されている。
最近では「みはりん坊ダブル」を使って絶対湿度の確認ができるということで人気が出ているようだ。ただ、残念なことにSwitchBotと違って表示されるだけでログをとることができない。(みはりん坊の表示をカメラで撮影して画像解析して数値をとる、というようなことをすれログが取れるかもしれないが…)
絶対湿度の計算自体はSwitchBotの温湿度計で測定した室温と相対湿度が分かればこのようなアプリやHPから簡単に計算できる。一応、計算式はこんな感じ(ただし単位はみはりん坊に合わせてg/m3)。VHが絶対湿度(g/m3)、RHが相対湿度(%)、tが室温(°C)。しかしこれではやはりログが取れないし少々面倒くさい。
VH=\frac{RH}{100}\cdot\frac{217\times6.1078\times10^{\frac{7.5t}{t+237.3}}}{t+273.15}
前回、Google apps scriptを使ってSwitchBot温湿度計のデータをGoogleスプレッドシートに記録できることができるようになっている。そこで、この結果をGoogleデータポータルに表示してSwitchBot温湿度計を絶対湿度のロガーにしてきたい。(SwitchBot温湿度計のログをCSVファイルで取り出してExcelで計算すれば「絶対湿度のログ」にできるじゃないか!という突っ込みはなしでお願いしたい。)
#2. 利用デバイス・事前準備
##2.1 利用デバイス
- SwitchBot温湿度計
- SwitchBot Hub mini
- Googleアカウント
##2.2 事前の準備
- 温湿度計の設定(アプリとの接続)を終わらせる
- クラウドサービスをオンにしてSwitchBot Hub miniと連携をさせておく
- プロフィール→設定→アプリバージョンを10回タップ(開発者向けオプション有効化)
- 開発者向けオプションからトークンを取得
※こちらを参考にさせていただいた
- デバイスID(MACアドレス)の取得
- SwitchBotのアプリから温湿度計を選択
- 右上の歯車マークから「設定」を開き「・・・」からMACアドレスを確認
- 「AA:AA:AA:AA:AA:AA」の形式になっているのでコロン以外の12桁の英数字をメモする
- 記録したい全ての温湿度計に対してこの操作を繰り返す
#3. GoogleAppsScriptのコード
-
Googleスプレッドシートで新しいスプレッドシートを作成する
-
各シートの1行目にヘッダーをつけておく
-
データポータルでの表示に備えてシートごとにヘッダーを変えておく
2枚目のシート(ヘッダーに1枚目シートとは異なる数字を振っておく)
- ツールからスクリプトエディタを開き以下のコードを記載する
function getJSON_SwitchBotHubMini(){
var headers = {"Authorization" : "token"}; //header情報として取得したトークンをtokenに記載
var options = {
"headers" : headers, //header情報を追加
}
//----------1つ目のSwitchBot温湿度計の記録------------
var url2 = "https://api.switch-bot.com/v1.0/devices/************/status"; //*に事前準備で取得したデバイスID(12桁英数字)を記載
var data = UrlFetchApp.fetch(url2,options); //1つ目の温湿度計のステータスを取得
var datajson=JSON.parse(data.getContentText());
var temp = datajson['body']['temperature']
var rhumidity = datajson['body']['humidity']
var ahumidity =217*(6.1078*10**(7.5*temp/(temp+237.3)))/(temp+273.15)*rhumidity/100 //絶対湿度(g/m^3)を算出
// 1つ目のシート取得
var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
var sheet = spreadsheet.getSheets()[0];
var date = new Date();
// データ入力
sheet.appendRow(["1つめのSwitchBot温湿度計",date,temp,rhumidity,ahumidity,1]); //温湿度計の名前は任意でつける。もちろんデバイスIDと紐づけて
var lastRow = sheet.getLastRow();
var range = sheet.getRange(lastRow-1, 6);
range.setValue(2); //データポータルでの表示に備えたIDの付与
//----------2つ目のSwitchBot温湿度計の記録------------
url2 = "https://api.switch-bot.com/v1.0/devices/E1B1233EED79/status"; //*に事前準備で取得したデバイスID(12桁英数字)を記載
data = UrlFetchApp.fetch(url2,options); //2つめの温湿度計のステータスを取得
datajson=JSON.parse(data.getContentText());
temp = datajson['body']['temperature']
rhumidity = datajson['body']['humidity']
ahumidity =217*(6.1078*10**(7.5*temp/(temp+237.3)))/(temp+273.15)*rhumidity/100 //絶対湿度(g/m^3)を算出
// 2枚目のシート取得
spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
sheet = spreadsheet.getSheets()[1];
date = new Date();
// データ入力
sheet.appendRow(["2つめのSwitchBot温湿度計",date,temp,rhumidity,ahumidity,1]); //温湿度計の名前は任意でつける
var lastRow = sheet.getLastRow();
var range = sheet.getRange(lastRow-1, 6);
range.setValue(2); //データポータルでの表示に備えたIDの付与
//----------3つ目のSwitchBot温湿度計の記録------------
//温湿度計の数だけ繰り返しで記載
}
※APIの取得が1日1000件までと限られているのでデバイスリストの取得は行わず直接、温湿度計のステータスを読みに行っている。
- 「トリガー」で定期実行の設定を行う
- イベントのソースを「時間主導型」
- 時間ベースのトリガーのタイプを「分ごとのタイマー」
- 時間の間隔を1分、5分、10分、15分、30分から選択
→
※タイマーの間隔は5分か10分を推奨(特にSwitchBot温湿度計の数が多い場合)
詳細は前回の記事の結果を参照ください。
以上で室温、相対湿度、絶対湿度がGoogleスプレッドシートに指定時間間隔ごとに記録されるようになる。
#4. Googleデータポータルでの表示
##4.1 ダッシュボードの作成とデータの連携
- Googleアカウントにログインした状態でデータポータルを開く
- 「空のレポート」から新しいダッシュボードを作成
- 「データに接続」から「Googleスプレッドシート」を選び、先ほど作ったスプレッドシートを選択 → その後ダッシュボードにデータを表示したいワークシートを選択 → 「追加」を押す
##4.2 スコアカードによる最新の温湿度の表示
- 「グラフを追加」から「スコアカード」を選択
- 「指標」から表示したい項目を選択
- 「指標」の左側の鉛筆マークから集計方法を「平均値」にする
- 「フィルターを追加」から「項目を選択」で「ID〇」(〇はここでシートごとに割り振った番号)を選び、「条件を選択」を「次に等しい (=)」として条件に「1」を入力する
- フィルターを保存すればGoogleスプレッドシートに記録されたものの中で最新の値がスコアカードに表示されるようになる
- 以上の操作を「温度」「相対湿度」「絶対湿度」に対して実行し、スコアカードを並べる
##4.3 時系列グラフによるログの表示
- 「グラフを追加」から「時系列グラフ」を選択
- ディメンションから「Date」のタイプを「日付、時、分」に変更
- 「指標」から表示したい項目を選択して集計方法を「平均値」にする
- 「デフォルトの日付範囲」から「詳細設定」を選び開始日に数字を入力する
- 数字が1であれば前日と今日の2日分、2であれば前々日からの3日分のログが表示できる
- 「スタイル」→ 「全般」から「欠損データ」を「線形補間」にしておく
- 以上の操作を「温度」「相対湿度」「絶対湿度」に対して実行し、時系列グラフを並べる
##4.4 ダッシュボードの公開、共有
- 自分自身のみで閲覧する場合
- 「共有」から「レポートへのリンクを取得」としてリンクをコピーし、スマホなどのブラウザから閲覧する
- 家族などで共有する場合
- 「共有設定を変更」から「アクセスを管理する」に移動し「リンクを知っている全員が表示できます」を選択
- リンクをコピーして閲覧してほしい人に共有する
#5 終わりに
これでSwitchBot温湿度計が絶対湿度ロガーとして機能するようになった。1個2000円程度の温湿度計で「温度」、「相対湿度」、「絶対湿度」のログが取れるというのは結構ありがたい。難点としてはGoogleスプレッドシート側の更新頻度が5分ごと(設定に寄る)、データポータルの更新頻度は15分ごと程度なので、「完全にリアルタイムの温湿度か?」と言われると少し前の温湿度を表示していることにはなる。しかし、そもそもSwitchBot温湿度計はBLE経由でも2分ごと、SwitchBot Hub mini経由であればおよそ30分毎にしか温湿度の値が更新されない。この点を考慮すると、それなりに近い段階での温湿度をログの取得も含めて実行できる、というだけで十分な気もする。
どうしてもリアルタイムに近いデータを取得したい場合はRaspberry Piを使うなどしてBluetooth Low Energy(BLE)でデータを取得してもらいたい。これはかなり色々な方の記事が出ているので参考になると思う。