Подтвердить что ты не робот

Получить лист по имени

Я пытаюсь получить следующую формулу для работы:

function setDataValid(range, sourceRange) {
  var rule = SpreadsheetApp.newDataValidation().requireValueInRange(sourceRange, true).build();
  range.setDataValidation(rule);
}

function onEdit() {
  var aCell = SpreadsheetApp.getActiveSheet().getActiveCell();
  var aColumn = aCell.getColumn();

  if (aColumn == 2 && SpreadsheetApp.getActiveSheet().getName() == 'Local' ) {
    var range = SpreadsheetApp.getActiveSheet().getRange(aCell.getRow(), aColumn + 1);
    var sourceRange = SpreadsheetApp.getActiveSpreadsheet().getRangeByName(aCell.getValue());
    setDataValid(range, sourceRange)
  }
}

При отладке onEdit() он показывает, что sourceRange в setDataValid (range, sourceRange) имеет значение NULL. Поскольку диапазон находится в моем листе "Локальный", я пытаюсь изменить getActiveSpreadsheet() на таблицу получения по имени. Кто может помочь?

4b9b3361

Ответ 1

Используйте в листе "Получить лист по имени":

var sheet = SpreadsheetApp.getActive().getSheetByName('Local')

Ответ 2

Пожалуйста, проверьте выражение

var sourceRange = SpreadsheetApp.getActiveSpreadsheet().getRangeByName(aCell.getValue());

Это должен быть тот, кто возвращает ноль. Чтобы узнать причину, посмотрите официальную документацию здесь.

var sourceRange = SpreadsheetApp.getActiveSpreadsheet().getRangeByName('Local!TaxRates')

должен получить диапазон.

Ответ 3

Очень просто получить лист по имени, синтаксис в соответствии с документацией.

    var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Expenses");