LoginSignup
5
1

More than 1 year has passed since last update.

Node-RED+LineBOTで健康管理チェックの予定だった!

Last updated at Posted at 2021-08-01

初めての物つくりで頭の中にあるアイデアと技術がなかなか思うように進まず悔しいです。
会社での健康管理チェックの改善策ように考えました。

やりたい事

毎朝ルーティーンでLineBotよりプッシュメッセージきて、
メッセージに対してのユーザの返信がそのままスプレッドシートに反映される事です。
ルーティーンに来るメッセージは下記になります。
・本日の天気予報
・「本日の体調は大丈夫ですか?」
 ⇒問に対して「はい」「いいえ」又は「〇」「✖」で回答。

使用

・LineBotアカウント
・Googleアカウント
・Node-REDアカウント
・steinアカウント
・Spreadsheet

作業

①Node-REDを立ち上げ下記のFlowを作成

node-red全体.png
★全体のフロー

②天気予報

1-1.png
1-2.png
★OpenweathermapのAPIをしたため、営業が固定になっている部分があり
 Changeノードで天気予報を日本語に変換する作業を追加しました。
1-3.png
★Injectノードの詳細
1-4.png
★openweathermapノードの詳細
1-5.png
★Line PushMessageノードはLINE Developer(SecretとAccessTakenとUserid)を入力します。
1-6.png
★最後にdebugノードの詳細

③健康チェックの問い

2-1.png
★1回だけの問いの場合はこれで行けますが、定期的に連絡来るようには
 下記の方法(繰り返し⇒指定した日時)でする事ができました。
2-1-2.png
★Injecノードの詳細
2-2.png
★LINE BloadcastMessageノードはLINE Developer(SecretとAccessTaken)を入力します。
★debugノードは天気予報で使用した内容と同じです。

④スプレッドシートのAPIで連携

LINEBot内で返信した内容をスプレッドシートに行こうする作業では、
SteinでスプレッドシートのAPIをゲットする事が出来たが、
返答分をうまく繋げる事が出来ず残念です。

色々な方法を調べ実施しました。
・Injectノード(文字列で「はい」⇒SteinノードでスプレッドシートのAPIを繋ぐ)
 試しにinjectボタンを押してもスプレッドシートには「はい」という文字が
 反映されませんでした。
3-1.png
★Injectノードの詳細
3-2.png
★stein-addrowsノードでスプレッドシートのAPIを繋ぎます。
 stein-addrowsはNode-REDのパレットの追加からのノードを追加する事が出来ます。
3-3.png

‣GAS(Google APPs Script)でスプレッドシートと連携

 スプレッドシートをGAS(Google APPs Script)からLINEBotに繋げる方法も
 やってみましたが、ネット上に出ているコードをコピして貼り付けて少し編集するだけで連携が出来るはずなんですが、
 今回、私は繋ぐこともできませんでした。やり方又はコードの編集方法が間違っていたのかもしれません。
GASでLINEからスプレッドシート.png

■結果

LINE上での最終結果としましてはこのような感じになりました。
IMG_6333.jpg

■まとめ

以上が業務改善のために健康管理チェックの自動化を考えていたのですが、
技術がともなわず未完成のままとなりました。
もの作りの初心者で上記を含め完成させるために良い方法/改善案などございましたら、
ぜひコメントをお待ちしております。

最後まで読んでいただきありがとうございます。

5
1
0

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
  3. You can use dark theme
What you can do with signing up
5
1