如何在源表单添加行时编写在一个工作表中添加行的脚本?

时间:2012-08-30 20:50:19

标签: javascript function google-apps-script google-sheets

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

我想帮助确定我需要添加到现有脚本的功能(或者我可以对其进行哪些更改),因此当源表中出现新行时(因为表单已提交),空白行显示在目标表中。

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

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();
    }

1 个答案:

答案 0 :(得分:0)

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

编辑:在编辑之后,我进一步测试了一下,appendRow()看起来不像我想的那样工作,它在一张空白纸的开头追加行...所以我试过这个:< / p>
  if(targetMax < values1.length) {
  var RowsToAdd = values1.length-targetMax
  for(nn=0;nn<RowsToAdd;++nn){targetSheet.insertRowAfter(targetMax)}
  }

只需将其放在var value6=...

之后即可 抱歉这个小错误; - )