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上,即(shareData1)
这里的问题是,当我使用 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++);
}
});
}
这个函数工作正常。当当前 sheet 不是 Google 表单响应时 sheet。我正在使用(每分钟)触发器
Image of: Sand data (mainData) sheet to (shareData1) sheet
- 我正在寻找一个,当用户提交状态为(付费)的Google表单时,数据应该在第二个sheet上,即(shareData1)
这里的问题是,当我使用 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++);
}
});
}