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

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

新規登録して質問してみよう
ただいま回答率
85.35%
Google Apps Script

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

Q&A

解決済

1回答

3749閲覧

Google Driveでフォルダ内のファイルが更新されたら、フォルダのURLをメール通知を送りたい

dell_0

総合スコア25

Google Apps Script

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

0グッド

0クリップ

投稿2021/06/28 04:12

下記のプログラムで運用をしていましたが、この結果に追加されたフォルダ自体のURLも取得したいと考えております。

//対象とするGoogleDriveフォルダのID ブラウザでアクセスしてURL見れば分かる var TARGET_FOLDER_ID = ""; //更新日時を記録するのスプレッドシートのID ブラウザでアクセスしてURL見れば分かる var UPDATE_SHEET_ID = ""; //スプレッドシートのシート名(下に表示されるタブのやつ) var UPDATE_SHEET_NAME = "シート1"; var SEND_MAIL_ADDRESS = ["name@example.co.jp","name2@example.co.jp"] 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) { SEND_MAIL_ADDRESS.forEach(function(o,i) { MailApp.sendEmail(SEND_MAIL_ADDRESS[i],targetFolder.getName() + "更新連絡通知", "【" + targetFolder.getName() + "】が更新されました。\n\n"+ updateText ); }); } }

現状の結果がこちらですが
イメージ説明

下記のようにアップデートされたフォルダのURLも出力したいと考えております。
イメージ説明

どのように指定をすればGoogleDriveのフォルダ自体のURLを取得できますでしょうか?

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

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

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

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

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

guest

回答1

0

ベストアンサー

下記のようにファイルIDからそのファイルが属する親フォルダのURLを返す関数を用意しておき、
フォルダ走査時に各ファイルの親フォルダURLを取得しておき、書き込んではいかがでしょうか。

// 指定したファイルIDの親フォルダURLを返す関数 function getParentUrls(fileId) { var file = DriveApp.getFileById(fileId); var parents = file.getParents(); var result = []; while (parents.hasNext()) { var parent = parents.next(); var parentUrl = parent.getUrl(); result.push(parentUrl); } // Google Driveの「複数フォルダへの所属機能」は2021年6月現在廃止されているため、resultの要素数が2つ以上になることはないと考えられるが、機能の復活等、要素数が2つ以上になった場合に備える。 return result.join(","); }

diff

1 allFilesId.forEach( 2 function( value, i ){ 3 var file =DriveApp.getFileById( value ); 4- lastUpdateMap[file.getName()] = {lastUpdate : file.getLastUpdated(), fileId: file.getId()};// 5+ lastUpdateMap[file.getName()] = {lastUpdate : file.getLastUpdated(), fileId: file.getId(), folderUrl: getParentUrls(file.getId())}; 6 7 } 8 );

diff

1 if(key in sheetData) { 2 // フォルダ名がシートに存在する場合。 3 if(lastUpdateMap[key].lastUpdate > sheetData[key].lastUpdate) { 4 // フォルダが更新されている場合。 5 sheet.getRange(sheetData[key].rowNo, 2).setValue(lastUpdateMap[key].lastUpdate); 6 sheet.getRange(sheetData[key].rowNo, 3).setValue(lastUpdateMap[key].fileId); 7+ sheet.getRange(sheetData[key].rowNo, 4).setValue(lastUpdateMap[key].folderUrl); 8 updateFolderMap.push({filename:key, lastUpdate:lastUpdateMap[key].lastUpdate, fileId:lastUpdateMap[key].fileId}); 9 } 10 } else { 11 // フォルダ名がシートに存在しない場合。 12 var newRow = sheet.getLastRow() + 1; 13 sheet.getRange(newRow, 1).setValue(key); 14 sheet.getRange(newRow, 2).setValue(lastUpdateMap[key].lastUpdate); 15 sheet.getRange(newRow, 3).setValue(lastUpdateMap[key].fileId); 16+ sheet.getRange(newRow, 4).setValue(lastUpdateMap[key].folderUrl); 17 updateFolderMap.push({filename:key, lastUpdate:lastUpdateMap[key].lastUpdate, fileId:lastUpdateMap[key].fileId}); 18 }

投稿2021/06/28 06:11

編集2021/06/28 06:16
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

dell_0

2021/06/28 06:32

ありがとうございます。 思ってた通りの動作になりました。 また、更新があった際にメールが飛ぶようにしているのですが、今回取得できるようになったフォルダURLも記載したいのですが、どのようにしたらよろしいでしょうか? // 新規及び更新された情報をメール送信。 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" }
dell_0

2021/06/28 06:49

すみません、こちら自己解決いたしました。 この度は、誠にありがとうございました。 大変勉強になりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問