循环以禁用 onEdit 脚本中的功能



我有一个脚本,通过单击复选框(具有是/否值(将特定值添加到工作表的最后一行,并通过取消选中相同的复选框来删除该行。它工作正常但正如它在编辑脚本上一样 - 它继续添加值。我正在尝试循环所有这些工作以检查值是否已存在,如果是 - 什么都不做。我开发了以下内容,但它不起作用 - 每次编辑都会不断添加值。这是代码

function onEdit() {
  var ss = SpreadsheetApp.getActiveSpreadsheet()
  var sheet = ss.getActiveSheet()
  var paramrange = sheet.getRange('A55:C60')
  var destn = sheet.getRange(sheet.getLastRow()+1, 1)
  var destnorma = sheet.getRange(sheet.getLastRow()+1, 2)
  var orpac = sheet.getRange('E23')
  var rows = sheet.getDataRange();
  var numRows = rows.getNumRows();
  var values = rows.getValues();
for (var i = 0; i <= numRows - 1; i++) {
         var row = values[i];
         if (row[0] == 'ORP Ac') {
         } else{
  if(orpac.getValue() == 'yes') {
      var orpacn = 'ORP Ac';
      var orpacnorm = '-150';
      destn.setValue(orpacn)
      destnorma.setValue(orpacnorm)
      } else
      { 
         var rows = sheet.getDataRange();
         var numRows = rows.getNumRows();
         var values = rows.getValues();
         var rowsDeleted = 0;
         for (var i = 0; i <= numRows - 1; i++) {
         var row = values[i];
         if (row[0] == 'ORP Ac') {
         sheet.deleteRow((parseInt(i)+1) - rowsDeleted);
         rowsDeleted++;
 }
 }}
}
}}

第二个循环位于第一个循环内,它使用相同的索引。 这是一个问题。

这可能会更好。 但我无法判断,因为我没有您的数据。

function onEdit() {
  var ss=SpreadsheetApp.getActive()
  var sheet=ss.getActiveSheet()
  var paramrange=sheet.getRange('A55:C60')
  var destn=sheet.getRange(sheet.getLastRow()+1, 1)
  var destnorma=sheet.getRange(sheet.getLastRow()+1, 2)
  var orpac=sheet.getRange('E23')
  var orpacvalue=orpac.getValue();
  var rows=sheet.getDataRange();
  var numRows=rows.getNumRows();
  var values=rows.getValues();
  for (var i=0;i<numRows;i++) {
    var row=values[i];
    if (row[0]!='ORP Ac') {      
      if(orpacvalue=='yes') {
        var orpacn = 'ORP Ac';
        var orpacnorm = '-150';
        destn.setValue(orpacn)
        destnorma.setValue(orpacnorm)
      } else
      { 
        var rows = sheet.getDataRange();
        var numRows = rows.getNumRows();
        var values = rows.getValues();
        var rowsDeleted = 0;
        for (var j = 0; j<numRows; j++) {
          var row = values[j];
          if (row[0] == 'ORP Ac') {
            sheet.deleteRow((parseInt(j)+1) - rowsDeleted);
            rowsDeleted++;
          }
        }
      }
    }
  }
}

对于需要在 30 秒内完成的简单触发器来说,这似乎是很多脚本。

最新更新