質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.12%

[LINE/GAS]シートで指定した複数のuserId宛てにメッセージを送りたい

受付中

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 821

negi_0919

score 16

 前提

・LINEBotで複数のユーザーにメッセージを送りたい
・使用しているものはGoogle Apps Scriptとスプレッドシートの2つです

 実現したいこと

スプレッドシートで指定したuserId宛て(複数)にメッセージを送りたい

 発生している問題

全く反応しない

 該当のソースコード

function doPost(e) {
  var token = PropertiesService.getScriptProperties().getProperty('CHANNEL_ACCESS_TOKEN'); 
  var reply_token= JSON.parse(e.postData.contents).events[0].replyToken;
  var user_id= JSON.parse(e.postData.contents).events[0].source.userId;
  var group_id= JSON.parse(e.postData.contents).events[0].source.groupId;
  if (user_id != undefined ) {
    var profile = get_profile(user_id);
  }
    var sheet = SpreadsheetApp.openById("(シートID)");

  switch (JSON.parse(e.postData.contents).events[0].type) {
    case 'message': //message event
      var user_message = JSON.parse(e.postData.contents).events[0].message.text;    
var url = "https://api.line.me/v2/bot/message/multicast";
  var headers = {
    "Content-Type" : "application/json; charset=UTF-8",
     'Authorization': 'Bearer ' + token,
  };
     var range = sheet.getRange(1, 2, 3);
  var postData = {
   "to" :[range.getValue()],
    "messages" : [
      {
        'type':'text',
        'text':"成功しました!"
      }
    ]
  };

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

function get_profile(userid) {
  var token = PropertiesService.getScriptProperties().getProperty('CHANNEL_ACCESS_TOKEN'); 
  var url = 'https://api.line.me/v2/bot/profile/' + userid;
  var headers = {
    'Authorization': 'Bearer ' + token
  };
  var options = {
    'headers' : headers
  };
  var response = UrlFetchApp.fetch(url, options);
  var content = JSON.parse(response.getContentText());  
  return content;  
}

 試したこと

送信先をリファレンス通りに記載した所、正常に動作しました
"to" :["userId①","userId②"],
が、実現したいことは"シートで指定した"userId(複数)宛てにメッセージを送信するという事なので
どなたか分かる方いましたら教えていただけると幸いです よろしくお願い致します

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • 退会済みユーザー

    退会済みユーザー

    2018/04/06 12:59

    質問の投げっぱなしはやめましょう。

    キャンセル

回答 2

+2

"to:{ユーザーIDの一次元配列}"で良いのなら以下のロジックで良いと思います。

  1. getValues()でユーザーID取得(二次元配列)
  2. ユーザーID配列の行列変換(行列転置)
  3. 変換後のユーザーID配列[0](目的の一次元配列)を"to":へセット

なお、昔、私も二次元配列の行列変換用の関数を自作しましたが、以下がスマートで参考になると思います。

[参考]
ワクガンス|JavaScriptの覚書 2次元配列の行列を入替

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

function doPost(e) {
    const token = PropertiesService.getScriptProperties().getProperty('CHANNEL_ACCESS_TOKEN');
    // const reply_token= e.postData.contents.events[0].replyToken;
    // const user_id= e.postData.contents.events[0].source.userId;
    // const group_id= e.postData.contents.events[0].source.groupId;
    // if (user_id != undefined ) {
    //     var profile = get_profile(user_id);
    // }
    const sheet = SpreadsheetApp.openById("(シートID)");

    switch (e.postData.contents.events[0].type) {
        case 'message': //message event
            // const user_message = e.postData.contents.events[0].message.text;
            const url = "https://api.line.me/v2/bot/message/multicast";
            const headers = {
                "Content-Type" : "application/json; charset=UTF-8",
                'Authorization': 'Bearer ' + token,
            };
            const range = sheet.getRange(1, 2, 3).getValues().map(function(e) {return e[0];});
            const postData = {
                "to" :range,
                "messages" : [
                    {
                        'type':'text',
                        'text':"成功しました!"
                    }
                ]
            };

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

// function get_profile(userid) {
//     const token = PropertiesService.getScriptProperties().getProperty('CHANNEL_ACCESS_TOKEN');
//     const url = 'https://api.line.me/v2/bot/profile/' + userid;
//     const headers = {
//         'Authorization': 'Bearer ' + token
//     };
//     const options = {
//         'headers' : headers
//     };
//     const response = UrlFetchApp.fetch(url, options);
//     return JSON.parse(response.getContentText());
// }

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.12%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる