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

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

新規登録して質問してみよう
ただいま回答率
85.45%
Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Gmail

GmailとはGoogleによって提供されているウェブメールのサービスのことです。

Google API

Googleは多種多様なAPIを提供していて、その多くはウェブ開発者向けのAPIです。それらのAPIは消費者に人気なGoogleのサービス(Google Maps, Google Earth, AdSense, Adwords, Google Apps,YouTube等)に基づいています。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

Q&A

解決済

1回答

4842閲覧

Googleスプレッドシートの更新履歴をGoogleChatに通知出来ない

penmon

総合スコア3

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Gmail

GmailとはGoogleによって提供されているウェブメールのサービスのことです。

Google API

Googleは多種多様なAPIを提供していて、その多くはウェブ開発者向けのAPIです。それらのAPIは消費者に人気なGoogleのサービス(Google Maps, Google Earth, AdSense, Adwords, Google Apps,YouTube等)に基づいています。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

0グッド

0クリップ

投稿2021/05/27 05:15

前提・実現したいこと

対象:Googleスプレッドシート/Google Chat/Gmail
実現したいこと:特定のシートを編集した時に、編集したという通知が「Gmail」「Google Chat」に送信される
背景:他人にスプレッドシートの更新を自動通知することで、報告の工数を削減したい

参照
Gmail通知:https://uyamazak.hatenablog.com/entry/2016/05/17/105126
Google Chat通知:https://qiita.com/Shin/items/72eaa5fa24b608c58b93

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

Google Chatに通知が来ない
※エラーメッセージは表示なし

推測

Gmailに通知を飛ばすコードに、自分でGoogle Chat通知用のコードを付け加えたので、
「if (updateFolderMap.length != 0) {」などが怪しいと考えているのですが、
調べても理解が出来なかったため、ご質問させて頂いております。

該当のソースコード

GAS

1 2//対象とするGoogleDriveフォルダのID ブラウザでアクセスしてURL見れば分かる 3var TARGET_FOLDER_ID = "フォルダのID"; 4//更新日時を記録するのスプレッドシートのID ブラウザでアクセスしてURL見れば分かる 5var UPDATE_SHEET_ID = "スプレッドシートのID"; 6//スプレッドシートのシート名(下に表示されるタブのやつ) 7var UPDATE_SHEET_NAME = "シート名"; 8var SEND_MAIL_ADDRESS = ["任意のメールアドレス"] 9 10//フォルダ~ファイルを定義 11function updateCheck() { 12 var targetFolder = DriveApp.getFolderById(TARGET_FOLDER_ID); 13 var folders = targetFolder.getFolders(); 14 var files = targetFolder.getFiles(); 15 16 //フォルダ内を再帰的に探索してすべてのファイルIDを配列にして返す 17 function getAllFilesId(targetFolder){ 18 var filesIdList = []; 19 20 var files = targetFolder.getFiles(); 21 while(files.hasNext()){ 22 filesIdList.push(files.next().getId()); 23 } 24 //階層が下に位置するフォルダも探索する 25 var child_folders = targetFolder.getFolders(); 26 while(child_folders.hasNext()){ 27 var child_folder = child_folders.next(); 28 //Logger.log( 'child_folder :' + child_folder ); 29 30 //Logger.log('getAllFilesId(child_folder):'+ getAllFilesId(child_folder)); 31 filesIdList = filesIdList.concat( getAllFilesId(child_folder) ); 32 } 33 return filesIdList; 34 } 35 //Logger.log('getAllFilesId(targetFolder):' + getAllFilesId(targetFolder)); 36 37 //すべてのファイルIDの取得変数を定義 38 var allFilesId = getAllFilesId(targetFolder); 39 var lastUpdateMap = {}; 40 //Logger.log(folders) 41 allFilesId.forEach( 42 function( value, i ){ 43 var file =DriveApp.getFileById( value ); 44 lastUpdateMap[file.getName()] = {lastUpdate : file.getLastUpdated(), fileId: file.getId()}; 45 } 46 ); 47 48 // スプレッドシートに記載されているフォルダ名と更新日時を取得。 49 var spreadsheet = SpreadsheetApp.openById(UPDATE_SHEET_ID); 50 var sheet = spreadsheet.getSheetByName(UPDATE_SHEET_NAME); 51 //Logger.log(sheet) 52 var data = sheet.getDataRange().getValues(); 53 //Logger.log('data: ' + data) 54 // 取得したデータをMapに変換。 55 var sheetData = {}; 56 for (var i = 0; i < data.length; i++) { 57 sheetData[data[i][0]] = {name : data[i][0], lastUpdate : data[i][1], rowNo : i + 1}; 58 } 59 60 // 実際のフォルダとスプレッドシート情報を比較。 61 var updateFolderMap = []; 62 for (key in lastUpdateMap) { 63 if( UPDATE_SHEET_ID == lastUpdateMap[key].fileId ){ 64 continue; 65 } 66 if(key in sheetData) { 67 // フォルダ名がシートに存在する場合。 68 if(lastUpdateMap[key].lastUpdate > sheetData[key].lastUpdate) { 69 // フォルダが更新されている場合。 70 sheet.getRange(sheetData[key].rowNo, 2).setValue(lastUpdateMap[key].lastUpdate); 71 sheet.getRange(sheetData[key].rowNo, 3).setValue(lastUpdateMap[key].fileId); 72 updateFolderMap.push({filename:key, lastUpdate:lastUpdateMap[key].lastUpdate, fileId:lastUpdateMap[key].fileId}); 73 } 74 } else { 75 // フォルダ名がシートに存在しない場合。 76 var newRow = sheet.getLastRow() + 1; 77 sheet.getRange(newRow, 1).setValue(key); 78 sheet.getRange(newRow, 2).setValue(lastUpdateMap[key].lastUpdate); 79 sheet.getRange(newRow, 3).setValue(lastUpdateMap[key].fileId); 80 updateFolderMap.push({filename:key, lastUpdate:lastUpdateMap[key].lastUpdate, fileId:lastUpdateMap[key].fileId}); 81 } 82 } 83 //Logger.log('updateFolderMap:' + updateFolderMap) 84 // 新規及び更新された情報をメール送信。 85 var updateText = ""; 86 for( key in updateFolderMap ){ 87 item = updateFolderMap[key]; 88 updateText += 89 item.filename + ' 更新日時:' + Utilities.formatDate(item.lastUpdate, "JST", "yyyy-MM-dd HH:mm:ss") + '\n' 90 + DriveApp.getFileById(item.fileId).getUrl() + "\n\n" 91 } 92 93 if (updateFolderMap.length != 0) { 94 SEND_MAIL_ADDRESS.forEach(function(o,i) { 95 MailApp.sendEmail(SEND_MAIL_ADDRESS[i],targetFolder.getName() + "更新連絡通知", 96 "【" + targetFolder.getName() + "】が更新されました。\n\n"+ 97 updateText 98 ); 99 }); 100 } 101 102 // google chatに投稿させる 103var url = 'GoogleChatのWebhook'; 104 if (updateFolderMap.length != 0) { 105 // 送信内容作成 106 let text = (targetFolder.getName() + "更新連絡通知", 107 "【" + targetFolder.getName() + "】が更新されました。\n\n"+ 108 updateText 109 ); 110 let message = {'text' : text} 111 let params = { 112 'method': 'POST', 113 'headers' : { 114 'Content-Type': 'application/json; charset=UTF-8' 115 }, 116 'payload':JSON.stringify(message) 117 }; 118 119 // 送信 120 UrlFetchApp.fetch(url, params); 121 } 122}

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Tatsunosuke

2021/05/27 07:50

>Gmailに通知を飛ばすコードに、自分でGoogle Chat通知用のコードを付け加えた Gmailに通知を飛ばすところまでは問題なく動作していますか?
penmon

2021/05/29 03:47

こちら翌朝通知が届いており、調査したところコードではなく通知設定の問題でした。 ご対応頂きありがとうございました。
guest

回答1

0

ベストアンサー

Gmailに通知を飛ばすコードに、自分でGoogle Chat通知用のコードを付け加えた

Gmailに通知を飛ばすところまでは問題なく動作していますか?

同じ環境で試せないので、質問者さんのご協力が大変重要です。
エラーがないということは、引数の中身が意図していないものが渡っているか、if文の条件ミスがほとんどです。

なので、どこまでのコードが問題なく処理されているかを調べる必要があります。
それぞれの区切りとなりそうな箇所にconsole.logやでデバッグ等で状況の確認をいただき、
教えていただけると改善のお手伝いができると思います!

投稿2021/05/27 13:50

Tatsunosuke

総合スコア599

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.45%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問