TypeError: не может вызывать метод «GetRange» NULL. (линия 0)
-
25-09-2019 - |
Вопрос
Я продолжаю получать эту ошибку, когда стараюсь запустить этот скрипт. Он пробился просто в течение нескольких дней. Он находится в электронной таблице Google Docs.
TypeError: не может вызывать метод «GetRange» NULL. (линия 0)
ss = SpreadsheetApp.getActiveSpreadsheet();
function onOpen() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var menuEntries = [ {name: "New PO", functionName: "NewPO"}];
ss.addMenu("New PO", menuEntries);
}
function NewPO() {
SpreadsheetApp.getActiveSheet().insertRowsBefore(1,6);
// Adjust this range accordingly, these are the cells that will be
// copied. Format is getRange(startRow, startCol, numRows, numCols)
ss.getSheetByName("PO Form").getRange(1, 1, 6, 8)
.copyTo(SpreadsheetApp.getActiveSheet().getRange(1, 1, 6, 8));
}
function onEdit(e) {
var ss = e.source.getActiveSheet();
var r = e.source.getActiveRange();
// 1 is A, 2 is B, ... 8 is H
if (r.getColumn() == 8 && r.getValue() == "x") {
r.setValue(Utilities.formatDate(new Date(), "GMT", "yyyy-MM-dd"));
}
}
Есть ли что-то, что вы можете видеть, что приведет к этой ошибке? В
Решение
Вы проверили возвращаемое значение ss.getSheetByName("PO Form")
. Отказ Скорее всего, это null
. Отказ У вас также есть переменная уровня класса по имениss
и метод переменные по имени ss
также. Такое тенение может привести к проблемам, если вы не очень осторожны.
Не связан с StackOverflow