Google Sheet 分叉(不适用于 Google 表单响应 Sheet )

Google Sheet Furcation ( Not Working on Google Form Response Sheet )

这个函数工作正常。当当前 sheet 不是 Google 表单响应时 sheet。我正在使用(每分钟)触发器

Image of: Sand data (mainData) sheet to (shareData1) sheet

这里的问题是,当我使用 Google 表单响应 sheet 时,此功能将不再起作用。它显示错误。 Error Image

在降级的错误图片中,我是手动运行这个函数,同样的错误出现在Executions AppScript面板中。

function doneCopy() {
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var sheet = ss.getSheetByName("mainData");
  var values = sheet.getRange(1, 3, sheet.getLastRow(), 1).getValues();

  var moveRows = values.reduce(function(ar, e, i) {
    if (e[0] == "Paid" ) ar.push(i + 1)
    return ar;

  }, []);

  var targetSheet = ss.getSheetByName("shareData1");

  moveRows.forEach(function(e) {
    sheet.getRange(e, 1, 1, sheet.getLastColumn()).moveTo(targetSheet.getRange(targetSheet.getLastRow() + 1, 1));
  });
  moveRows.reverse().forEach(function(e) {sheet.deleteRow(e)});
}

function doneCopy() {
  const ss = SpreadsheetApp.getActiveSpreadsheet();
  const sh = ss.getSheetByName("mainData");
  const tsh = ss.getSheetByName("shareData1");
  const vs = sh.getRange(1, 3, sh.getLastRow(), 1).getValues().flat();
  const n = sh.getLastColumn();
  let d = 0;
  vs.forEach((e, i) => {
    if (e == 'Paid') {
      sh.getRange(i + 1, 1, 1, n).copyTo(tsh.getRange(tsh.getLastRow() + 1, 1));
      sh.deleteRow(i + 1 - d++);
    }
  });
}

我不确定你的额外需求是什么,但我会尽力猜测。

function doneCopy() {
  const ss = SpreadsheetApp.getActiveSpreadsheet();
  const sh = ss.getSheetByName("mainData");
  const tsh = ss.getSheetByName("shareData1");
  const vs = sh.getRange(1, 3, sh.getLastRow(), 1).getValues().flat();
  const n = sh.getLastColumn();
  const a = ['Paid','Process'];
  let d = 0;
  vs.forEach((e, i) => {
    if (~a.indexOf(e)) {
      sh.getRange(i + 1, 1, 1, n).copyTo(tsh.getRange(tsh.getLastRow() + 1, 1));
      sh.deleteRow(i + 1 - d++);
    }
  });
}