4
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

【GAS】雨が降りそうな日に通知してくれる LINE BOT を作る

Last updated at Posted at 2019-10-01

:star: 作るもの

雨が降りそうな日の朝にLINEでメッセージを届けるようにします。

unnamed.jpg
(1個だけごみ捨てのメッセージが混ざってますが、これは別です。)

:scissors: 使うもの

・LINE Developersアカウント
・Google App Script
・Liverdoor Weather API

:exclamation: おおまかな流れ

・LINE Developersに登録
・プロパイダを作成
・チャネル(BOTのアカウント)を作成
・BOTと友達になる
・GASでAPIを叩いて雨が降りそうか判定するスクリプトを作る
・GASからLINE BOTを介して自分にメッセージを送らせる
・毎朝このスクリプトを実行するように設定する

:boom: LINEのDevelopers設定編

LINE Developersに登録

https://developers.line.biz/ja/
LINE Developers Top.png

LINEアカウントを持っていれば簡単に登録出来ると思います。

※UIなどは記事執筆時点のものなので多少変わるかもしれません

プロパイダを作成

LINE Developers.png
ログインが済むと上のような画面になると思うので、新規プロバイダを作成します。
普通に開発者自身の情報を入れて行けば良いです。

チャネルの作成

LINE Developers2.png

次にチャネルの作成です。「新規チャネル作成」を押します。
チャネルと言うと何かややこしいですが、BOTの登録だと思ったら良いと思います。

LINE Developers3.png

今回の用途では「Messaging API」を選択します。
次の画面で、アプリ名やアイコンなど好きに設定したらええんちゃうかな。

作ったBOTと友達になる

作成したチャネルの設定画面の下の方に行くと、QRコードがあります。
ここから友達登録をすると良いと思います。
LINE Developers 7.png

メモっておくもの

  • アクセストークン
    チャネルの設定画面の中盤くらいにあります
    「-」になっていたら「再発行」を押す
    LINE Developers4.png

  • 自分のID
    チャネルの設定画面の一番下にあります
    ※この自分のIDとは友達検索とかで使うIDとは違います
    LINE Developers6.png

:boom: Google App Script編

Apps Script – Google Apps Script.png

Googleアカウントは持っている前提で行きます。

ここの「Start Scripting」から App Script を始めることが出来ます。
ダッシュボードに入ったら左上くらいにある「新規スクリプト」を押してスクリプト編集画面を開きます。

具体的なコードの例

とりあえず先にコードを貼ります。

function main() {
  
  // お天気APIを読んで結果をもらう
  const result = callWeatherAPI();
  
  // 正常にAPIから応答があるか
  if (result.getResponseCode() !== 200) {
    
    // 異常があればメッセージを失敗を知らせるものにする
    var message  = "何か失敗しました。レスポンスコード:" + result.getResponseCode();
  
  } else {
    
    // 正常ならデータをJSONにパース
    var data =  JSON.parse(result.getContentText()).forecasts[0].telop;
    
    // 結果に雨という文字が含まれないなら何もせず中断する
    if(data.split("").indexOf("") == -1) {
      return;
    }
    
    // メッセージを設定
    var message = "今日は雨が降るかもしれません。\n\n予報:" + data;
    
  }
  
  // LINEへ送信
  var line_access_token = "YOUR_ACCESS_TOKEN";
  var line_to = "YOUR_LINE_TO";
  sendToLine(line_access_token, line_to, message);

}

// *******************************************
// Livedoorのお天気APIを叩いてレスポンスをもらう関数
// *******************************************
function callWeatherAPI() {
  const response = UrlFetchApp.fetch(
    "http://weather.livedoor.com/forecast/webservice/json/v1?city=400010", // TODO: set your city number
    {
      "method" : "get",
      "headers" : {
        "Content-Type": "application/json"
      },
      "muteHttpExceptions": true
    }
  );
  return response;
}

// *******************************************
// LINEボットへ送信する関数
// *******************************************
function sendToLine(access_token, to, message) {
  var url = "https://api.line.me/v2/bot/message/push";
  var headers = {
    "Content-Type" : "application/json; charset=UTF-8",
    'Authorization': 'Bearer ' + access_token,
  };

  var postData = {
    "to" : to,
    "messages" : [
      {
        'type':'text',
        'text': message,
      }
    ]
  };

  var options = {
    "method" : "post",
    "headers" : headers,
    "payload" : JSON.stringify(postData)
  };

  return UrlFetchApp.fetch(url, options);
}

このままでは動かないので、編集しないといけない部分があります。

LINEの設定部分

中盤のこの部分

  var line_access_token = "YOUR_ACCESS_TOKEN";
  var line_to = "YOUR_LINE_TO";

ここをそれぞれLINE Developers編でメモったアクセストークンと自分のIDに差し替える必要あり。

どの都市の天気を取得するかの設定

const response = UrlFetchApp.fetch(
    "http://weather.livedoor.com/forecast/webservice/json/v1?city=400010", 

デフォルトだと九州の久留米になっています。

都市のIDやパラメータの設定などはこちら参照。
今のところAPI KEYなどは不要なようです。

関数を実行する

編集画面上部の再生ボタンみたいなマークを押すと関数を実行出来ます。

この時、実行する関数は「main()」関数にします。
「関数を選択」からmain関数が指定されているのを確認してください。

wheather_forecast.png

各項目が正常に指定できていれば、さっき作ったボットからメッセージが送られてくる...と言いたいところですが、雨の予報でなければ送られてきません。

    // 結果に雨という文字が含まれないなら何もせず中断する
    /*
  if(data.split("").indexOf("雨") == -1) {
      return;
    }
    */

この部分をこのようにコメントアウトすれば、とりあえずどんな予報でも「今日は雨が降るかもしれません: 予報内容」というメッセージが届くと思います。

挙動を確認したらコメントアウトを元に戻しておきましょう。

定期実行を行う

今度はこれを自動的に毎朝実行出来るようにしたいです。
GASはかなり簡単に定期実行が出来るようになってます。

まずスクリプト編集画面上部にある時計みたいなアイコンをクリックします。
wheather_forecast2.png

するとトリガー一覧画面に移るので「トリガーを追加」をクリック。
wheather_forecast - プロジェクトのトリガー - Apps Script.png

実行する関数を「main」にして、「日付ベースのタイマー」を選択。
時間は好みで良いです、朝の6時~7時とかが良いんじゃないでしょうか。

weather_forecast - プロジェクトのトリガー - Apps Script2.png

:umbrella: 結果

毎朝、天気予報が雨の場合はメッセージが届くようになります。

冒頭と同じ画像ですが...以下のように。

unnamed.jpg
4
6
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
4
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?