I am not a coder, and trying to manipulate some code (pre-existing/ some added from a partner) but still struggling on small section/ issue.
script (original) written to getRow with active
// Get the number of the row to move
var rowToMove = activeSheet.getActiveRange().getRow();
Logger.log("rowToMove: " + rowToMove);
trying change to have it getRow based on cell value. Have gotten it to where it searches defined range. But trying to get it to, based on the value, preform the getRow as it did in the code above... not successful.
any suggestions welcome, happy to provide more info as well.
function moveRows(){
Logger.log("moveRows.gs > moveRows");
// Confirmation check
var ui = SpreadsheetApp.getUi();
var response = ui.alert("Move Row", "Confirm Completed Tasks", ui.ButtonSet.YES_NO);
if (response == ui.Button.YES) {
// Start: Get the data to move
// Get the current sheet object
var activeSheet = SpreadsheetApp.getActiveSheet();
// Get the number of columns
var lastColumnOfDataInActiveSheet = activeSheet.getLastColumn();
Logger.log("lastColumnOfDataInActiveSheet: " + lastColumnOfDataInActiveSheet);
**// Get the number of the row to move
var rowToMove = activeSheet.getRange('E2:E500').getValues();
rowToMove.forEach( function (r, i) {
Logger.log(r);
if (r[0])
activeSheet.getRow();
});
// Get the range to move
var rangeToCopyFrom = activeSheet.getRange(rowToMove, 1, 1, lastColumnOfDataInActiveSheet);**
// End: Get the data to move
// Start: Copy and paste the data
// Get the target sheet
var targetSheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Completed");
// Get last row in target sheet
var lastRowInTargetSheet = targetSheet.getLastRow();
Logger.log("lastRowInTargetSheet: " + lastRowInTargetSheet);
// Get range to paste to
var rangeToPasteTo = targetSheet.getRange(lastRowInTargetSheet + 1, 1, 1, lastColumnOfDataInActiveSheet);
// Copy and paste the data
rangeToCopyFrom.copyTo(rangeToPasteTo, {contentsFormat:true});
// End: Copy and paste the data
// Clear the source data
rangeToCopyFrom.clearContent();
// Sort the source sheet
var lastRowOfDataInActiveSheet = activeSheet.getLastRow();
var rangeToSort = activeSheet.getRange(2, 1, lastRowOfDataInActiveSheet - 1, lastColumnOfDataInActiveSheet);
rangeToSort.sort({column: 1, ascending: true});
// Pop up box tells you it's done
}; // End: Confirmation check
}; // End: moveRows
function moveRows(){
var ui = SpreadsheetApp.getUi();
var response = ui.alert("Move Row", "Confirm Completed Tasks", ui.ButtonSet.YES_NO);
if (response == ui.Button.YES) {
var ash = SpreadsheetApp.getActiveSheet();
var avs = ash.getRange('E2:E500').getValues();
avs.forEach( function (r, i) {
if (r[0])
ash.getRow();//there is no sheet.getRow();
});
var srg = ash.getRange(avs, 1, 1, ash.getLastColumn());//avs is a two dimensional array of data not a number
var tsh = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Completed");
var trg = tsh.getRange(tsh.getLastRow() + 1,1);
srg.copyTo(trg, {contentsFormat:true});
srg.clearContent();
var rangeToSort = ash.getRange(2, 1, ash.getLastRow() - 1, ash.getLastColumn());
rangeToSort.sort({column: 1, ascending: true});
};
};
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.