Несколько / Дублирование строк по уникальному ключу - PullRequest
0 голосов
/ 11 марта 2019

В Google Sheets, используя Apps Script, у меня есть 3 листа, которые я хочу взять ключи из листа 1 и продублировать строки из листа 2 напротив них, чтобы для каждого уникального ключа заполнялось каждое значение из листа 2. Смотрите лист 3 в качестве примера вывода. Обратите внимание, что на листе 1 ключи появляются только один раз, но мне нужно дублировать ключи, чтобы соответствовать количеству строк на листе 2.

Есть идеи?

Лист 1: содержит уникальные ключи

Лист 2: Содержит значения, которые я хотел умножить / дублировать

Лист 3: содержит желаемый результат.

лист 1

лист 2

лист 3

Ответы [ 2 ]

3 голосов
/ 11 марта 2019

Вы можете прочитать столбцы 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.

1 голос
/ 13 марта 2019

Для 2 столбцов из Sheet2 используйте это -

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 2 columns, [ [value1, value2], [value1, value2], [value1, value2]... ]
  var v2 = s2.getRange(2, 1, s2.getLastRow() - 1, 2).getValues();

  // hold rows to insert, will become [row, row]
  var result = [];

  v1.forEach(function(k) {
    v2.forEach(function(v) {
      // create row as [k, v1, v2]
      // change needed here if Sheet3 row has to be combo of Sheet2 cols
      result.push([k].concat(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, 3).setValues(result);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...