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

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

ただいまの
回答率

87.91%

スプレッドシートとslackの連携でエラー400が出てしまいます。

解決済

回答 2

投稿

  • 評価
  • クリップ 1
  • VIEW 4,305

score 8

前提・実現したいこと

Google Apps Scriptを使ってスプレッドシートとslackを連携させようとしています。
スプレッドシートの該当セルをslack上に投稿するといったものです。

発生している問題・エラーメッセージ

function postSlack 実行時に
UrlFetchApp.fetch(url, options);
にて下記エラーが表示されます。

https://hooks.slack.com のリクエストに失敗しました(エラー: 400)。
サーバー応答の一部: missing_text_or_fallback_or_attachments
(応答の全文を見るには muteHttpExceptions オプションを使用してください)

該当のソースコード

function postSlack() {
  var obj = SpreadsheetApp.openById('スプレッドシートのID');
  var sheet = obj.getSheetByName('スプレッドシートのシート名');
  var range = sheet.getRange('該当セル');
  var values = range.getValues();
  var text = values;


  var payload  = {
    'text'      :  text, 
    'username'  : '吾輩',  
    'channel'   : 'チャンネル名',  
    'icon_emoji': ':アイコン:',   
 };

  var options = {
    'method'      : 'post',
    'contentType' : 'application/json',
    'payload'     : JSON.stringify(payload),

  };  
var url = 'Incoming WebhookのURL';
UrlFetchApp.fetch(url, options);

}

試したこと

ネットで色々と探し、
"muteHttpExceptions" : true,
"validateHttpsCertificates" : false,
"followRedirects" : false,
というものを入れたり、try〜catchというのも試してみましたが、slack上には吐き出されませんでした。
また、「'text':text」の箇所を「'text':'テスト'」といった形で文字にすると吐き出されました。
GASをかじりたての初心者ですので、試したことがあっているかどうかもわかりかねるのですが、
解決法をご教示いただけると大変助かります。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

+1

該当セルではなくA2とかで書いてください。また、例えば何が入るのかデータサンプルを示してください

別回答へのコメントも拝見しましたが、slackはテキスト本文がない、または空白からなるメッセージであるのことを許容しません。

また
getValuesとしていますがこれではobject[][]が取得できてしまいます。
例えばこうしたらどうでしょうか。

  var range = sheet.getRange('該当セル');
  var values = range.getValue().toString();
  var text = values || "empty";

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/10/08 18:49

    大変失礼いたしました。
    今後該当セルではなく実際のA2等で記載するようにいたします。
    また、データサンプルとしては「電話番号」や「10/08」といったものになります。

    なお、ご提示いただいた方法で試してみたのですが、無事投稿をすることができました。
    本やネットを見ながらの無知で大変恐縮なのですが、解決された原因がわかっておらず、
    >object[][]が取得できてしまいます。
    こちらはどういう意味だったのでしょうか?

    新しく追記いただいた
    toStringは「文字列に変換」
    || "empty"は「valuesか"empty"のどちらかがtrueならばtrue」
    というところは理解できました。
    ※なお、|| "empty"を無しでやってみたところ、それでも吐き出しされました。

    助けていただきありがとうございましたm(_ _)m

    キャンセル

  • 2019/10/09 08:14

    このコードだと日付はもしかしたら意図した表示にならないかも。

    疑問点については、getValuesは二次元配列を返すという意図です。例えばB5のような単独セルであっても、1✕1の表と考えて二次元配列が返されます。
    これで解決し、またvalueのところのemptyを外しても動作するなら、このJSON.stringifyではオブジェクトや配列を上手く文字列化してくれないのではないかと思います。

    蛇足ですが、jsの||はこの記号の左がtruelyだったら左を、左がfalsyだったら右を返すという動作をします。なので、該当セルに何らかの文字が埋まっているなら、間引きした内容がなくても動作するのは想定挙動です。そのセルの内容を消して動作を比べると、emptyがないときのみ質問と同じエラーが発生する、が想定動作であり、この句が解決したい実装上の課題です。

    キャンセル

  • 2019/10/10 18:04

    ご回答ありがとうございました。
    ご教示いただいた内容を改めて自分でも調べてみて、理解ができました。(おそらく)
    実際のコードでご記載いただけて大変助かりました。
    ありがとうございました。

    キャンセル

+1

文字列はOK で、変数にするとNGということは、変数 text の中身が、Slack が認めている値ではないのではないでしょうか?

変数の値は何でしょうか?

変数の中身を確認して、送信する内容がSlack が、要求している書式になっているか確認するとどうなっていますか?

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/10/08 10:15

    ご返答ありがとうございます。
    変数の値はスプレッドシートのセルに入っている文字(自分の名前など)になります。
    Logger.log(text)でログを見ると、その文字はログには出てきております。
    ※すみません、回答になっておりますでしょうか、、、?

    キャンセル

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

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

同じタグがついた質問を見る