[英]Google Script to Move Multiple Rows Simultaneously to Another Sheet - Archive Rows and Delete Completed
我正在嘗試將多行同時從一個Google工作表移至另一行。
我想在一天結束時運行一次腳本,以存檔所有完整的作業。
只要目標單元格不是空白,我放在一起的腳本一次只能移動2行。 理想情況下,它將繼續循環並僅移動標記為“完成”的作業。
我正在使用的工作表在這里
function onOpen() {
var ui = SpreadsheetApp.getUi();
ui.createMenu('Admin')
.addItem('Archive', 'archive')
.addToUi();
}
function archive()
{
var ss = SpreadsheetApp.getActiveSpreadsheet();
var sheet = ss.getSheetByName("Scheduled");
var range = sheet.getRange('A5:Q200');
var sheetToMoveTheRowTo = "Archive";
var numRows = sheet.getLastRow();
var row = sheet.getRange(5,1);
for (var row = 5; row < numRows; row++)
{
var status = sheet.getRange(row,1).getValue();
if ( status == "Complete") {
var targetSheet = ss.getSheetByName(sheetToMoveTheRowTo);
var targetRange = targetSheet.getRange(targetSheet.getLastRow() + 1, 1);
sheet.getRange(range.getRow(),1,1, sheet.getLastColumn()).moveTo(targetRange);
sheet.deleteRow(range.getRow());
}
}
}
存檔,Google表格,移動,行,電子表格,刪除
您應該將所有數據設置為一次存檔。 您無法一次刪除所有行,但可以保存要刪除的行,然后循環瀏覽行號。
我將代碼設置為如下所示:
function archive() {
var arrayOfRowsToArchive,data,i,lastColumn,L,numRows,range,rowsToDelete,
ss,sheet,sheetToMoveTheRowTo,startRow,status,targetSheet,thisRowsData;
//USER INPUT:
startRow = 5;
//END OF USER INPUT
ss = SpreadsheetApp.getActiveSpreadsheet();
sheet = ss.getSheetByName("Scheduled");
sheetToMoveTheRowTo = "Archive";
numRows = sheet.getLastRow();
lastColumn = sheet.getLastColumn();
arrayOfRowsToArchive = [];
rowsToDelete = [];
data = sheet.getRange(startRow, 1, numRows - startRow, lastColumn).getValues();//Get all values except the header rows
L = data.length;
for (i=0; i < L; i++) {
status = data[i][0];
//Logger.log('status: ' + status);
if ( status === "Complete") {
thisRowsData = data[i];//Only get inner array of data
//Logger.log('thisRowsData: ' + thisRowsData)
arrayOfRowsToArchive.push(thisRowsData);//Push one row of data to outer array
rowsToDelete.push(i+startRow);//Get the row number to delete later
}
}
targetSheet = ss.getSheetByName(sheetToMoveTheRowTo);
targetSheet.getRange(targetSheet.getLastRow()+1, 1, arrayOfRowsToArchive.length, arrayOfRowsToArchive[0].length)
.setValues(arrayOfRowsToArchive);
//Logger.log('rowsToDelete: ' + rowsToDelete)
for (i=rowsToDelete.length;i>0;i--) {//Delete from bottom up
Logger.log((i-1).toString())
Logger.log('rowsToDelete[i-1]: ' + rowsToDelete[i-1])
sheet.deleteRow(rowsToDelete[i-1]);
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.