こんにちは、仕事で食品検査を担当しています
入社してまもなく半年、デジタルに関する知識はほぼ0ですが、家の遠い私が定時で帰宅するために業務の効率化ができないか模索しはじめました(笑)
今回デジタルで解決できそうなプチ課題があったので、取り組んだ過程を紹介したいと思います
1. 取り組み背景
検査室には多数の冷蔵庫、冷凍庫があります
検査の信頼性を保つためにも、きちんと設定温度通り動いているか、毎日作業前と作業後に点検をする必要があります
しかし、この点検方法が、各機械の前に行っておんどとり(データが記録できる小型の温度計)の数値を確認し、紙の点検表に記載するというアナログのものでした
<おんどとり子機の写真>
検査室で使用するおんどとりには、無線で温度データを確認できるという機能がついています(おんどとり Web Storage)
ボタン一つで点検作業ができたら楽で時間削減になると思い、プログラミングの知識がなくてもそれっぽいものができるMakeとLINEを使って、自動点検LINE Botを作成してみました
2. 使用ツール
Make
LINE
おんどとりAPI
Google スプレッドシート(記録用)
3. 実施内容
3.1. ベース作成
Botの作成方法やMakeとの接続方法については省略します
HTTPモジュールに、おんどとりAPIホームページに記載されている項目をいれていきます
Request contentに、アカウント情報や動かしたいおんどとりの情報、やってほしいことをJSON形式で入力します
API KEYが必要になりますが、こちらのやり方はホームページに書かれています
まずはこの状態で返信用LINEモジュールとつなぎ、Data
が返ってくるようにします
<Request content内容例>
返信メッセージは下のような訳のわからない英数字の羅列に見えますが、Parse JSONというモジュールを使ってこの羅列を読み取ると、本来の意味にわかりやすく変換してくれます
{"devices":[
{"num":"6","serial":"528237D8","model":"RTR502B","name":"50-EB326(2\u2103~8\u2103)","battery":"5","rssi":"3","time_diff":"540","std_bias":"0","dst_bias":"0","unixtime":"1662409159","channel":[{"num":"1","name":"","value":"4.3","unit":"C"}],"baseunit":{"serial":"58580787","model":"RTR500BW","name":"RTR500BW_58580787"},"group":{"num":"1","name":"Group1"}}
]}
あとは返信メッセージに、確認したい温度value
をいれれば完成です
これだけのことですが、希望の返事がきたときは、初心者の私にはかなり嬉しい出来事でした
3.2. ちょっと応用
次にこれをちょっと発展させます
LINEのメッセージでデータを確認するのもいいですが、記録は保管する必要があり、従業員全員が閲覧できる形で残さなければなりません
このままでは返ってきた温度データを点検表に転記するという手作業が発生します
そこでGoogle Sheetsモジュールを使用して、記録も自動でやってしまおうと考えました
本モジュールは複数の種類があり、目的に合わせて選択します
ここでは行を追加するというものでやってみました
使用するGoogle Sheetsを選択し、どこの列に何をいれるか指示します
私には、できあがった表をファイル形式や画像形式で送る術はなかったので、LINEの返信は「点検完了しました」というシンプルなテキストにしました
動画、写真は後ほどでてくるものと同様なので割愛します
3.3. 実戦
では本命の検査室の冷蔵冷凍庫(15台)のデータを一度に表にするという作業に挑戦します
複数台のデータを得る方法として、ホームページでも紹介されていた、シリアル番号をカンマで区切って欲しい分だけ並べてリクエストする方法、
おんどとりごとにHTTPモジュールを作る方法があります
前者がシンプルで簡単だと思ったので、試してみました
ん?同じ温度?
念のため、おんどとりWeb Storageでデータを確認するも明らかに異なる温度を表示しています
原因はわからないけど、返信メッセージをわけてみたらうまくいくかなと思い試すも今度はエラー発生
LINE Botのリプライトークンは一度しか使えないのだそうです(そんな多分基本的なことも知らないレベルです汗)
仕方ない、見栄えは美しくなくても動けばいい、力技でつなげるべし!とひたすら単純作業を繰り返しました
いけー
がんばって動いてくれているが失敗作…
— hosaka (@Rhosaka21) September 11, 2022
APIの制限をきちんと理解せず使った結果、利用回数の上限超えてました😭#protoout#力技#きっと無駄じゃない#Makeのオペレーション回数もしっかり稼いだ pic.twitter.com/53rW49TYzr
けなげに一つづつ動いていのがかわいいです
無事返信もきました
恐る恐るシートを開くと、、、
おお!できてる!
がんばったかいがあったなと、シートを横にスクロールしたところ
ん?シートが途中までしか埋まっていない
なんで10個しかデータ出てないの?という緊急事態に
Makeに戻ってエラーコードを確認してみると、
「APIの利用上限を超過しています」
・・・
あ!
3.4. 思わぬ落とし穴
そういえばホームページにこんなこと書いてあったけど、何言ってるかわからずスルーしていました
つまり青色のモジュールは、このAPIの場合2分間で10回までしか使えないということです
あんなにがんばってつなげたのに
と悲しみ、困っていたところ、ともにデジタルに関する勉強をする方から「引数」というワードを教えてもらいました
これはプログラムに渡す追加の注文のようなものだそうです
つまり、引数を指定すれば、先のカンマ区切り方式でもおんどとりごとのデータをもらえるかも?ということで
レッツ引数チャレンジ!
JSONの右上の1を押してどのおんどとりにどの引数が割り当てられているか確認、
Google Sheetsモジュールの希望列のところにvalue
を選択し、devices[
と]: channel[
の間に引数をいれます
3.5. 完成品
最終結果がこちら
先ほどのものに比べてかなりシンプルになりました
点検表は、温度が基準内にあるか判定をしてくれるシートと、記録用に保存するシートを作りましたメッセージを送ると、おんどとりの現在値を確認し、温度が管理基準内か判定してくれて、同時にスプレッドシートに記録してくれるLINE Bot
— hosaka (@Rhosaka21) September 7, 2022
注:表が動くのは一瞬です
#protoout #おんどとり pic.twitter.com/YD1J0WCzuq
プログラミング言語や仕組みがなにもわからない私でも、それっぽいものを作ることができました!!
4. 今後の課題
完成翌日、気分ルンルンで上司に報告したところ、
データで温度を確認するからには一時点のみの記録でなく、前回の点検時からの動態をみるべきだよね、あと冷蔵冷凍庫だけじゃなくてインキュベーターにも使いたいよね
というフィードバックをいただきました
うう
でもおっしゃる通り、それにこのAPIには指定した一定期間のデータを得るという機能もついています
時間を指定するのに必要な“unixtime”への自動変換など、まだわからないところもありますが、今後の課題としてチャレンジしてみようと思います
以上日々の点検業務をちょっと楽にするかもしれないアイデアでした
読んでいただきありがとうございました
5. 追記 New!
上司からのフィードバックをうけて、さらなるチャレンジ
グラフデータで動態を確認しない代わりに、一定期間のデータを取得し、その最大値、最小値、平均値を記録してくれるようなシートを作成することにしました
おんどとりAPIにて、一定期間のデータ取得→最大値、最小値、平均値をGoogle Sheetsに記録
— hosaka (@Rhosaka21) September 11, 2022
ができるLINE Bot
#protoout #おんどとり #LINEBot pic.twitter.com/14myQ7ep3F
<最終形態>
<作成したシートたち>
unixtimeは写真にある計算で、見慣れた形式の時間に変更できました!
<HTTPモジュール中身>
<Google Sheetsモジュールたちの中身>
技術的にはやっていることはほとんど変わりません
HTTPモジュールの中身を指定期間・件数によるデータの取得に変更して、16:30~翌日8:30の間の点検を想定し、64個分(16時間分:15分に1度の取得に設定してあるため)の直近データを得るようにRequestしました
64個引数をいれるのはきつかったので、1時間に1つ分Getするものになっています
Google Sheetsで関数計算したものを別のシートに転記するのにいい方法がわからず、Search Rowsを3つつなげる不恰好な流れになってしまいました
何か方法があれば教えていただきたいです
また、この指定期間のデータ取得は、複数の子機の指定ができないため、再び力技をしなければいけない気がして(このAPIは20回/60秒の上限なのでできるっちゃできる?)、今回はあきらめました
(欲しいのはおんどとり15台分なので、1時間おきにしても240回引数入れる必要が…、むしろそれを自動化したい…)
とりあえずここまでが今の私ができる限界です
他のツールと組み合わせたら、実際に使えそうなものができるかもしれません
挑戦はまだまだ続きます
最後までお付き合いいただき、ありがとうございました!