类型错误:无法调用“getRange”空的。 (第0行)
-
25-09-2019 - |
题
我一直当我尝试运行此脚本收到此错误。它运行得很好了好几天。它是在一个谷歌文档电子表格。
空的不能调用方法“getRange”:类型错误。 (第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
还有一类级别的变量namedss
和方法变量。如果你不小心,这种阴影会导致问题。
不隶属于 StackOverflow