TypeError:无法调用null的方法“getRange”。 (第0行)

时间:2010-11-18 03:43:26

标签: google-apps-script google-sheets

我在尝试运行此脚本时遇到此错误。它运行好几天了。它位于Google文档电子表格中。

TypeError:无法调用null的方法“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"));
  }
}

有什么可以看到会导致此错误的内容吗?

1 个答案:

答案 0 :(得分:4)

您是否检查了ss.getSheetByName("PO Form")的返回值。这很可能是null。您还有一个名为ss的类级变量和名为ss的方法变量。如果你不是很小心的话,这种阴影会导致问题。