Reputation: 15
I'm looking for a script to achieve the following. Tried googling few codes but they don't seem to address what I require. And since I'm new to scripts, I'm kind of lost on this.
Thank you in advance.
The code I was trying the modify for this is follows;
var searchFor ='title contains "2013"';
var names =[];
var files = DriveApp.searchFiles(searchFor);
while (files.hasNext()) {
var file = files.next();
names.push(file.getName());
}
var folders = DriveApp.searchFolders(searchFor);
while (folders.hasNext()) {
var file = folders.next();
names.push(file.getName());
}
for (var i=0;i<names.length;i++){
Logger.log(names[i]);
}
}```
Upvotes: 1
Views: 2255
Reputation: 27348
Here is my solution. Feel free to change the size range of column H ('H2:Hx') :
function myFunction() {
var folderId = '#FolderId';
var folder = DriveApp.getFolderById(folderId)
var extension = '.xlsx';
var source = SpreadsheetApp.getActiveSpreadsheet();
var sheet = source.getSheetByName('Sheet1');
var RowSize=sheet.getRange('H:H').getValues().filter(String).length; //calculate max value of rows
var file_name=sheet.getRange('H2:H'+RowSize).getValues()
var file_checker=sheet.getRange('K2:K'+RowSize).getValues()
for (i = 0; i < file_name.length; i++) {
if (file_checker[i][0]=="Complete"){break;}
var files = folder.getFilesByName(file_name[i][0]+extension)
while (files.hasNext()) {
var childFile = files.next();
var file_url = childFile.getUrl()
sheet.getRange(i+2,9).setValue(file_url);
} // while
} //for
} // function
Upvotes: 2