0

我有一个填充谷歌电子表格(源表)的谷歌表单。我找到并自定义了一个脚本,以将某些列(整体)从源工作表中拉到一个新的选项卡/工作表中。显然,两个工作表中的行数必须相同,脚本才能正常运行。如果不是,它会返回一个错误。每次提交新表单时,都会在源工作表中添加一行,使两个工作表不同步并破坏脚本。

我想帮助弄清楚我需要向现有脚本添加什么功能(或者我可以对其进行哪些更改),因此当源工作表中出现新行时(因为已提交表单),会出现一个空白行在目标表中。

我需要调整脚本或添加新功能吗?

function importFunction(a) {
  var ss = SpreadsheetApp.openById("0ApTaY3v27-UqdElwZTBvanNpaC1UckpxaTJRZS1XNWc");
  var sourceSheet = ss.getSheets()[0];
  var ss2 = SpreadsheetApp.openById("0ApTaY3v27-UqdElwZTBvanNpaC1UckpxaTJRZS1XNWc");
  var targetSheet = ss2.getSheets()[1];
  var values1 = sourceSheet.setActiveSelection("C:C").getValues();
  var values2 = sourceSheet.setActiveSelection("AD:AD").getValues();
  var values3 = sourceSheet.setActiveSelection("D:E").getValues();
  var values4 = sourceSheet.setActiveSelection("AE:AE").getValues();
  var values5 = sourceSheet.setActiveSelection("F:H").getValues();
  var values6 = sourceSheet.setActiveSelection("N:U").getValues();
  targetSheet.setActiveSelection("A:A").setValues(values1);
  targetSheet.setActiveSelection("B:B").setValues(values2);
  targetSheet.setActiveSelection("C:D").setValues(values3);
  targetSheet.setActiveSelection("E:E").setValues(values4);
  targetSheet.setActiveSelection("F:H").setValues(values5);
  targetSheet.setActiveSelection("I:P").setValues(values6);
}

根据下面的建议,我尝试将脚本更改为以下内容,但出现错误 - 找不到方法 appendRow()。我该如何解决?

    function importFunction(a) {
      var ss = SpreadsheetApp.openById("0ApTaY3v27-UqdElwZTBvanNpaC1UckpxaTJRZS1XNWc");
      var sourceSheet = ss.getSheets()[0];
      var ss2 = SpreadsheetApp.openById("0ApTaY3v27-UqdElwZTBvanNpaC1UckpxaTJRZS1XNWc");
      var targetSheet = ss2.getSheets()[1];
      var targetMax = targetSheet.getMaxRows();
      var values1 = sourceSheet.setActiveSelection("C:C").getValues();
      var values2 = sourceSheet.setActiveSelection("AD:AD").getValues();
      var values3 = sourceSheet.setActiveSelection("D:E").getValues();
      var values4 = sourceSheet.setActiveSelection("AE:AE").getValues();
      var values5 = sourceSheet.setActiveSelection("F:H").getValues();
      var values6 = sourceSheet.setActiveSelection("N:U").getValues();
      if(targetMax == values1.length) {
        targetSheet.setActiveSelection("A:A").setValues(values1);
        targetSheet.setActiveSelection("B:B").setValues(values2);
        targetSheet.setActiveSelection("C:D").setValues(values3);
        targetSheet.setActiveSelection("E:E").setValues(values4);
        targetSheet.setActiveSelection("F:H").setValues(values5);
        targetSheet.setActiveSelection("I:P").setValues(values6);
      }
      else
        targetSheet.appendRow();
    }
4

1 回答 1

0

您可以在使用getMaxRows()写入值之前简单地检查工作表 SS2 中的可用行数,并将其与数据数组的长度进行比较value1.length,然后,根据此比较,最终使用appendRow()添加您需要的行 for下一个循环。

编辑:在您的编辑之后,我进行了进一步测试,它似乎appendRow()不像我想的那样工作,它在空白表的开头附加 Rows ......所以我尝试了这个:

  if(targetMax < values1.length) {
  var RowsToAdd = values1.length-targetMax
  for(nn=0;nn<RowsToAdd;++nn){targetSheet.insertRowAfter(targetMax)}
  }

直接放在后面var value6=...

抱歉这个小错误;-)

于 2012-08-30T21:25:45.967 回答