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

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

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

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

Google Apps Script

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

メール

メールは、コンピュータネットワークを利用し、 情報等を交換する手段のことです。

Q&A

解決済

1回答

6339閲覧

Google Driveでフォルダ内のファイルが更新されたら通知メールを送るGoogle Apps Script(GAS)

o_t_hallelujah

総合スコア1

Google スプレッドシート

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

Google Apps Script

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

メール

メールは、コンピュータネットワークを利用し、 情報等を交換する手段のことです。

0グッド

0クリップ

投稿2021/12/14 09:59

前提・実現したいこと

Google Apps Script(GAS)でGoogle Driveに新しいファイルが追加されたら通知メールが送信されるシステムを作っています。
送信先メールアドレスをコードで直接書き込むのではなく、スプレッドシート上のメールアドレスに一斉送信されるようにしたいのですが、
補足情報の2つのコードをくっつけるだけではうまくいかず困っています。

構成としては、
スプレッドシートからメールアドレスを取得するfunction main() 、
Google Driveに新しいファイルが追加されたら通知メールが送信されるfunction updateCheck()を
を順に並べています。

function main() で宣言したMAIL_ADDRESS_LISTのアドレスにfunction updateCheck()で通知メールを送りたいのですが、
補足情報2のサイトのコードをSEND_MAIL_ADDRESS(アドレス直接入力)からMAIL_ADDRESS_LISTに変えても通知メールが送られません。

試したことの項目にも書きましたが、MAIL_ADDRESS_LISTをグローバル変数として宣言しても、
function main()で格納したメールアドレスがfunction updateCheck()を実行する際に消えてしまいます。

全くの初心者のため、わかりにくい点が多々あるかと思います。申し訳ありません。
お知恵を貸していただきたく、よろしくお願いいたします。

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

function updateCheck()を実行すると実行完了となるが通知メールが送られない。
(デバッグ画面ではfunction main() で宣言したMAIL_ADDRESS_LISTがfunction updateCheck()で変数に表示されない。)
(UPDATE_SHEET_IDで宣言したスプレッドシートは更新される。)

エラー ReferenceError: MAIL_ADDRESS_LIST is not defined

該当のソースコード

//以下補足情報1と同じ function main() { var ADDRESS_SHEET_ID = "xxxxxxxxxxxxxxxxxx"; var spreadsheet = SpreadsheetApp.openById(ADDRESS_SHEET_ID); var sheet = spreadsheet.getSheetByName('シート1'); // 1 const firstRow = 4; //データの開始行(=今回は4行目) const mailCol = 3; //メールアドレスの列(=今回はC列) // 2 var rowLength = sheet.getLastRow() - (firstRow - 1); // 3 var MAIL_ADDRESS_LIST = []; // 4 for(let i=0; i < rowLength; i++){ let address = sheet.getRange(firstRow + i, mailCol).getValue(); MAIL_ADDRESS_LIST.push(address); console.log(MAIL_ADDRESS_LIST); } return MAIL_ADDRESS_LIST } //以下補足情報2とほぼ同じ、SEND_MAIL_ADDRESSをMAIL_ADDRESS_LISTに変えた。 //対象とするGoogleDriveフォルダのID ブラウザでアクセスしてURL見れば分かる var TARGET_FOLDER_ID = "xxxxxxxxxxxxxx"; //更新日時を記録するのスプレッドシートのID ブラウザでアクセスしてURL見れば分かる var UPDATE_SHEET_ID = "xxxxxxxxxxxxxxxxxx"; //スプレッドシートのシート名(下に表示されるタブのやつ) var UPDATE_SHEET_NAME = "シート1"; function updateCheck() { var targetFolder = DriveApp.getFolderById(TARGET_FOLDER_ID); var folders = targetFolder.getFolders(); var files = targetFolder.getFiles(); //フォルダ内を再帰的に探索してすべてのファイルIDを配列にして返す function getAllFilesId(targetFolder){ var filesIdList = []; var files = targetFolder.getFiles(); while(files.hasNext()){ filesIdList.push(files.next().getId()); } var child_folders = targetFolder.getFolders(); while(child_folders.hasNext()){ var child_folder = child_folders.next(); //Logger.log( 'child_folder :' + child_folder ); //Logger.log('getAllFilesId(child_folder):'+ getAllFilesId(child_folder)); filesIdList = filesIdList.concat( getAllFilesId(child_folder) ); } return filesIdList; } //Logger.log('getAllFilesId(targetFolder):' + getAllFilesId(targetFolder)); var allFilesId = getAllFilesId(targetFolder); var lastUpdateMap = {}; //Logger.log(folders) allFilesId.forEach( function( value, i ){ var file =DriveApp.getFileById( value ); lastUpdateMap[file.getName()] = {lastUpdate : file.getLastUpdated(), fileId: file.getId()}; } ); // スプレッドシートに記載されているフォルダ名と更新日時を取得。 var spreadsheet = SpreadsheetApp.openById(UPDATE_SHEET_ID); var sheet = spreadsheet.getSheetByName(UPDATE_SHEET_NAME); //Logger.log(sheet) var data = sheet.getDataRange().getValues(); //Logger.log('data: ' + data) // 取得したデータをMapに変換。 var sheetData = {}; for (var i = 0; i < data.length; i++) { sheetData[data[i][0]] = {name : data[i][0], lastUpdate : data[i][1], rowNo : i + 1}; } // 実際のフォルダとスプレッドシート情報を比較。 var updateFolderMap = []; for (key in lastUpdateMap) { if( UPDATE_SHEET_ID == lastUpdateMap[key].fileId ){ continue; } if(key in sheetData) { // フォルダ名がシートに存在する場合。 if(lastUpdateMap[key].lastUpdate > sheetData[key].lastUpdate) { // フォルダが更新されている場合。 sheet.getRange(sheetData[key].rowNo, 2).setValue(lastUpdateMap[key].lastUpdate); sheet.getRange(sheetData[key].rowNo, 3).setValue(lastUpdateMap[key].fileId); updateFolderMap.push({filename:key, lastUpdate:lastUpdateMap[key].lastUpdate, fileId:lastUpdateMap[key].fileId}); } } else { // フォルダ名がシートに存在しない場合。 var newRow = sheet.getLastRow() + 1; sheet.getRange(newRow, 1).setValue(key); sheet.getRange(newRow, 2).setValue(lastUpdateMap[key].lastUpdate); sheet.getRange(newRow, 3).setValue(lastUpdateMap[key].fileId); updateFolderMap.push({filename:key, lastUpdate:lastUpdateMap[key].lastUpdate, fileId:lastUpdateMap[key].fileId}); } } //Logger.log('updateFolderMap:' + updateFolderMap) // 新規及び更新された情報をメール送信。 var updateText = ""; for( key in updateFolderMap ){ item = updateFolderMap[key]; updateText += item.filename + ' 更新日時:' + Utilities.formatDate(item.lastUpdate, "JST", "yyyy-MM-dd HH:mm:ss") + '\n' + DriveApp.getFileById(item.fileId).getUrl() + "\n\n" } //ここからエラーになる if (updateFolderMap.length != 0) { MAIL_ADDRESS_LIST.forEach(function(o,i) { MailApp.sendEmail(MAIL_ADDRESS_LIST[i],targetFolder.getName() + "更新連絡通知", "【" + targetFolder.getName() + "】が更新されました。\n\n"+ updateText ); }); } }

試したこと

  • function main()だけ書いて実行

→メールアドレスの取得可能。
実行ログにメールアドレスが表示される。
デバッグの変数のところにも例えば「Array(1)」となってメールアドレスが出る。

  • function updateCheck()だけ書いて実行

→補足情報2のようにメールアドレスを入れて、
if (updateFolderMap.length != 0) {
SEND_MAIL_ADDRESS.forEach(function(o,i) {
MailApp.sendEmail(SEND_MAIL_ADDRESS[i],targetFolder.getName() + "更新連絡通知",
"【" + targetFolder.getName() + "】が更新されました。\n\n"+
updateText
とすれば通知メール送信可能。

  • function main()の

// 3
var MAIL_ADDRESS_LIST = [];
をfunction mainの上に移動してグローバル変数として宣言
→通知メールが送信されない。
function updateCheck()でも変数は定義されているが、Array(0)となり
function main()では表示されていたメールアドレスが消える。

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

参考にしたサイト
1 スプレッドシートからメールを一斉送信するGAS
https://blog.synnex.co.jp/google/sending-email-from-spreadsheet/)

2 Google Driveでフォルダ内のファイルが更新されたらメール通知を送るGoogle Apps Script
https://uyamazak.hatenablog.com/entry/2016/05/17/105126)

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

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

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

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

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

guest

回答1

0

ベストアンサー

main()関数は、「スプレッドシートからメールアドレスデータを読み取り、配列にして返す関数」となっているようですので、
下記のようにしてみてはいかがでしょうか。
(function updateCheck()関数終盤の、下記先頭行が「+」となっている位置に下記コードを追加して、updateCheck()を定期実行する)

diff

1 2function updateCheck() { 3(略) 4// ここからエラーになる 5 6+ MAIL_ADDRESS_LIST = main(); // 追加 7 if (updateFolderMap.length != 0) { 8 MAIL_ADDRESS_LIST.forEach(function(o,i) { 9 MailApp.sendEmail(MAIL_ADDRESS_LIST[i],targetFolder.getName() + "更新連絡通知", 10 "【" + targetFolder.getName() + "】が更新されました。\n\n"+ 11 updateText 12 ); 13 }); 14 } 15}

投稿2021/12/14 11:27

編集2021/12/14 11:29
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

o_t_hallelujah

2021/12/15 00:17

ご回答ありがとうございました。 無事解決いたしました。 本当にありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問