Вы можете прочитать столбцы Key и Values и использовать значения для создания записываемых строк для Sheet3.Ниже приведен код простого подхода к выполнению этой функции в test
функции, которую можно скопировать / вставить и запустить.
function test() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var s1 = ss.getSheetByName('Sheet1');
var s2 = ss.getSheetByName('Sheet2');
var s3 = ss.getSheetByName('Sheet3');
// read Key column, [ [value], [value], [value]... ]
var v1 = s1.getRange(2, 1, s1.getLastRow() - 1, 1).getValues();
// flatten array of arrays into array, [value, value...]
v1 = v1.map(function(el) {
return el[0];
});
// read Values column, [ [value], [value], [value]... ]
var v2 = s2.getRange(2, 1, s2.getLastRow() - 1, 1).getValues();
// flatten array of arrays into array, [value, value...]
v2 = v2.map(function(el) {
return el[0];
});
// hold rows to insert, will become [row, row]
var result = [];
v1.forEach(function(k) {
v2.forEach(function(v) {
// create row as [k, v]
result.push([k, v]);
});
});
// get range of required length and insert values into sheet
// 2, which row to start, 1, which col to start, result.length, how many rows, 2, how many cols
s3.getRange(2, 1, result.length, 2).setValues(result);
}
См. this для map
, this для forEach
, это для SpreadsheetApp
и это для sheet
.