Цикл для отключения функции в скрипте onEdit - PullRequest
0 голосов
/ 05 июня 2019

У меня есть скрипт, который добавляет определенные значения в последнюю строку листа, установив флажок (имеет значения да / нет), и удаляет строку, сняв этот флажок.Он работает нормально, но, как и сценарий 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++;
 }
 }}

}
}}

1 Ответ

0 голосов
/ 05 июня 2019

Ваш второй цикл находится внутри первого цикла и использует тот же индекс. Это проблема.

Это может сработать лучше. Но я не могу сказать, так как у меня нет ваших данных.

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 секунд.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...