I'm looking for a script that generates 2 formulas in Col16 and Col17 when Col15 is edited . My formulas from the Google functions are:
I need this script to be run for 5 sheets called "Miriam", "Elisa", "Victor", "Hanane", "Sarah".
function onEdit(event) {
// assumes source data in sheet named Elisa-Miriam-Victor-Hanane-Sarah-Apoorva
// target sheet of move to named Archive
// getColumn with check-boxes is currently set to column 2 or B
var ss = SpreadsheetApp.getActiveSpreadsheet();
var s = event.source.getActiveSheet();
var r = event.source.getActiveRange();
// When a client is mentioned in Col3, fill automatically Col23 or W by the PM name and generate the checkbox from data validation in Col2 or B
var lastRow = s.getLastRow();
var col23 = s.getRange(lastRow, 23).getValue();
if (r.getRow() == lastRow && r.getColumn() == 3 && col23 == ""){
s.getRange(lastRow, 23).setValue(s.getSheetName());
var rule = SpreadsheetApp.newDataValidation().requireCheckbox().build()
s.getRange(lastRow,2).setDataValidation(rule);
}
// Fill automatically Columns P and Q when PO number is provided in Column O.
//In P: generates the date of when the PO is mentioned; in Q: it generates the PO folder name
var sh=event.range.getSheet();
var namesA=["Miriam","Elisa","Hanane","Sarah","Apoorva","Victor"];
if(namesA.indexOf(sh.getName())!=-1 && e.range.columnStart==15) {
event.range.offset(0,1).setValue(new Date()).setNumberFormat("yyyy-MM-dd");
event.range.offset(0,2).setFormula(Utilities.formatString('=CONCATENATE(P%s,"-",E%s,P%s)',event.range.rowStart,event.range.rowStart,event.range.rowStart));
}
// Archive a project with checked box from Archive Sheet
if((s.getName() == "Miriam"||s.getName() == "Elisa"||s.getName() == "Hanane"||s.getName() == "Sarah"||s.getName() == "Apoorva"||s.getName() == "Victor")&& r.getColumn() == 2 && r.getValue() == true) { // copy past every time a new PM-sheet is added
var row = r.getRow();
var numColumns = s.getLastColumn();
var targetSheet = ss.getSheetByName("Archive");
var target = targetSheet.getRange(targetSheet.getLastRow() + 1, 1);
s.getRange(row, 1, 1, numColumns).moveTo(target);
s.deleteRow(row);
}
// Unarchive a project from Archive sheet to respective owner
else if(s.getName() == "Archive" && r.getColumn() == 2 && r.getValue() == false) {
var row = r.getRow();
var nameColumn = 23;
var name = s.getRange(row, nameColumn).getValue();
var numColumns = s.getLastColumn();
var targetSheet = ss.getSheetByName(name);
var target = targetSheet.getRange(targetSheet.getLastRow() + 1, 1);
s.getRange(row, 1, 1, numColumns).moveTo(target);
s.deleteRow(row);
}
}
I managed to generate in Col16 the date of when Col15 is edited. But I don't understand why the script is not working for Col17 with the concatenate formula .
Try this:
function onEdit(e) {
var sh=e.range.getSheet();
var namesA=["Miriam","Elisa","Hanane","Sarah","Apoorva","Victor"];
if(namesA.indexOf(sh.getName())!=-1 && e.range.columnStart==15) {
e.range.offset(0,1).setValue(new Date()).setNumberFormat("yyyy-MM-dd");
e.range.offset(0,2).setFormula(Utilities.formatString('=CONCATENATE(P%s,"-",E%s,P%s)',e.range.rowStart,e.range.rowStart,e.range.rowStart));
}
}
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.