GAS & V8:如何在 Check True 的选项卡之间移动行
GAS & V8: how to move rows in between tabs on Check True
GAS 脚本:在复选框上移动行
我需要在 checkbox = TRUE 时将行移动到其他选项卡,但以下代码使我的 sheet 崩溃,因为它非常慢。我怎样才能让它更快?我在这里有点窒息。
已更新
如何在不使用 for 循环且不使 sheet 崩溃的情况下检查整个文档中的 boxes = true?
Check
ID
Product
☑
1
3456
☑
2
TOPRPR
[]
3
AZECRT
function onEdit(event) {
// assumes source data in sheet named main
// target sheet of move to named Completed
// getColumn with check-boxes is currently set to column 4 or D
var ss = SpreadsheetApp.getActiveSpreadsheet();
var s = event.source.getActiveSheet();
var r = event.source.getActiveRange();
if(s.getName() == "main" && r.getColumn() == 4 && r.getValue() == true) {
var row = r.getRow();
var numColumns = s.getLastColumn();
var targetSheet = ss.getSheetByName("Completed");
var target = targetSheet.getRange(targetSheet.getLastRow() + 1, 1);
s.getRange(row, 1, 1, numColumns).moveTo(target);
s.deleteRow(row);
} else if(s.getName() == "Completed" && r.getColumn() == 4 && r.getValue() == false) {
var row = r.getRow();
var numColumns = s.getLastColumn();
var targetSheet = ss.getSheetByName("discart");
var target = targetSheet.getRange(targetSheet.getLastRow() + 1, 1);
s.getRange(row, 1, 1, numColumns).moveTo(target);
s.deleteRow(row);
}
}
function onEdit(e) {
//e.source.toast('entry');
//Logger.log(JSON.stringify(e));
const sh = e.range.getSheet();
if(sh.getName() == "main" && e.range.columnStart == 4 && e.value == "TRUE") {
let tsh = e.source.getSheetByName("Completed");
sh.getRange(e.range.rowStart, 1, 1, sh.getLastColumn()).moveTo(tsh.getRange(tsh.getLastRow() + 1, 1));
sh.deleteRow(e.range.rowStart);
} else if(sh.getName() == "Completed" && e.range.columnStart == 4 && e.value == "FALSE") {
let tsh = e.source.getSheetByName("discart");
let trg = tsh.getRange(tsh.getLastRow() + 1, 1);
sh.getRange(e.range.rowStart, 1, 1, sh.getLastColumn()).moveTo(trg);
sh.deleteRow(e.range.rowStart);
}
}
GAS 脚本:在复选框上移动行
我需要在 checkbox = TRUE 时将行移动到其他选项卡,但以下代码使我的 sheet 崩溃,因为它非常慢。我怎样才能让它更快?我在这里有点窒息。
已更新
如何在不使用 for 循环且不使 sheet 崩溃的情况下检查整个文档中的 boxes = true?
Check | ID | Product |
---|---|---|
☑ | 1 | 3456 |
☑ | 2 | TOPRPR |
[] | 3 | AZECRT |
function onEdit(event) {
// assumes source data in sheet named main
// target sheet of move to named Completed
// getColumn with check-boxes is currently set to column 4 or D
var ss = SpreadsheetApp.getActiveSpreadsheet();
var s = event.source.getActiveSheet();
var r = event.source.getActiveRange();
if(s.getName() == "main" && r.getColumn() == 4 && r.getValue() == true) {
var row = r.getRow();
var numColumns = s.getLastColumn();
var targetSheet = ss.getSheetByName("Completed");
var target = targetSheet.getRange(targetSheet.getLastRow() + 1, 1);
s.getRange(row, 1, 1, numColumns).moveTo(target);
s.deleteRow(row);
} else if(s.getName() == "Completed" && r.getColumn() == 4 && r.getValue() == false) {
var row = r.getRow();
var numColumns = s.getLastColumn();
var targetSheet = ss.getSheetByName("discart");
var target = targetSheet.getRange(targetSheet.getLastRow() + 1, 1);
s.getRange(row, 1, 1, numColumns).moveTo(target);
s.deleteRow(row);
}
}
function onEdit(e) {
//e.source.toast('entry');
//Logger.log(JSON.stringify(e));
const sh = e.range.getSheet();
if(sh.getName() == "main" && e.range.columnStart == 4 && e.value == "TRUE") {
let tsh = e.source.getSheetByName("Completed");
sh.getRange(e.range.rowStart, 1, 1, sh.getLastColumn()).moveTo(tsh.getRange(tsh.getLastRow() + 1, 1));
sh.deleteRow(e.range.rowStart);
} else if(sh.getName() == "Completed" && e.range.columnStart == 4 && e.value == "FALSE") {
let tsh = e.source.getSheetByName("discart");
let trg = tsh.getRange(tsh.getLastRow() + 1, 1);
sh.getRange(e.range.rowStart, 1, 1, sh.getLastColumn()).moveTo(trg);
sh.deleteRow(e.range.rowStart);
}
}