Created
September 7, 2017 17:17
-
-
Save jsdbroughton/7d354526d708ec6c8ae07cdb2507bccc to your computer and use it in GitHub Desktop.
Google Sheets Custom Function that takes a list of sheet names and performs a VLOOKUP type search for the range, key and column reference given.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/** | |
* Returns an array of indirect single cell references from different sheets. | |
* @param {A2:A} sheets The column containing sheets' names. | |
* @param {"E1"} ref The range to return from each sheet. | |
* @param {string} key Value to match | |
* @param {int} column The column from which to return a value | |
* @param {int} headers The number of header rows to ignore in the lookup range | |
* @customfunction | |
*/ | |
function ILOOKUP(sheets, ref, keys, column, headers) { | |
var ss = SpreadsheetApp.getActiveSpreadsheet(), | |
result = []; | |
headers = headers || 0; | |
var sheetList = (!sheets.map) ? [[sheets]] : sheets; | |
var keyList = (!keys.map) ? [[keys]] : keys; | |
if (keyList.length != sheetList.length) { | |
if (keyList.length == 1) { | |
keyList = Array(sheetList.length).fill(keys); | |
} else { | |
throw("Matching Keys should equal the number of referenced sheets"); | |
} | |
} | |
for (var i = 0, l = sheets.length; i < l; i+=1) | |
{ | |
if (sheets[i] !='') { | |
var values = ss.getSheetByName(sheets[i][0]).getRange(ref).getValues().slice(headers); | |
var columnValues = values.filter(function(row){ | |
return row[0] == keyList[i]; | |
}).map(function(row, i){ return row[column-1]; }); | |
result.push(columnValues); | |
} else { | |
result.push([0]); | |
} | |
} | |
// balance column in results | |
var maxCols = result.reduce(function(count, row){ return (count < row.length) ? row.length : count; },0); | |
result = result.map(function(row){ | |
if (row.length < maxCols) { | |
return row.concat(Array(maxCols - row.length).fill(0)); | |
} | |
return row; | |
}); | |
//return JSON.stringify(result); | |
return result; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment