LANG SELRCT

Apps Script Reference  (Create: Create new Spreadsheet | Create new Apps Script

Sunday, October 22, 2017

LINE BOTでメッセージに応じてデータを返す


入力したテキストに応じて返すデータを変えるということをやってみましょう


LINE BOTをつくる方法はこちらの記事にまとめました


返すテキストは
if文を使って
入力されたテキストに応じて
設定します

var input_text = e.message.text;
var reply_text = "";
if (input_text == "こんにちは") {
  reply_text = "元気?";
} else if (input_text == "hello") {
  reply_text = "how are you?";
}


コード.gs
var CHANNEL_ACCESS_TOKEN = "TOKEN";

function doPost(e) {
  var contents = e.postData.contents;
  var obj = JSON.parse(contents);
  var events = obj["events"];
  for (var i = 0; i < events.length; i++) {
    if (events[i].type == "message") {
      reply_message(events[i]);
    }
  }
}

function reply_message(e) {
  if (e.message.type == "text") {
    var input_text = e.message.text;
    var reply_text = "";
    if (input_text == "こんにちは") {
      reply_text = "元気?";
    } else if (input_text == "hello") {
      reply_text = "how are you?";
    }
    var postData = {
      "replyToken": e.replyToken,
      "messages": [{
        "type": "text",
        "text": reply_text
      }]
    };
  }
  var options = {
    "method": "post",
    "headers": {
      "Content-Type": "application/json",
      "Authorization": "Bearer " + CHANNEL_ACCESS_TOKEN
    },
    "payload": JSON.stringify(postData)
  };
  UrlFetchApp.fetch("https://api.line.me/v2/bot/message/reply", options);
}

意訳.gs
アクセストークンを設定する

この処理は以下を実行する
送信されたデータの内容を取得し
そのJSONをオブジェクトに変換し
eventsを取得する
eventsの数だけ以下を繰り返す
もしtypeがmessageなら
reply_messageに渡す




この処理は以下を実行する
もし受け取ったmessageのtypeがtextなら
そのtextを取得して
reply_textの入れ物を用意して
もしtextが こんにちは なら
元気? を返し
もしtextが hello なら
how are you? を返し

postDataに
replyTokenを設定し
messagesの
typeを設定し
textを設定し



optionsに
methodを設定し
headersに
Content-Typeを設定し
Authorizationを設定し

payloadにはpostDataをJSONに変換したものを設定する

optionをつけてLINEのmessage reply APIをたたく




Latest post

スプレッドシートA列にある複数のテキストをスライドに追加したい(Google Apps Script)

今回Google Apps Scriptでやりたいこと GoogleスプレッドシートA列にある複数の値を取得して Googleスライドに渡して 図形オブジェクトのテキストとして追加したい ① スプレッドシートのA列に値を入れておく ② Code.gsのinsertNewShape...