尝试创建一个Google表格,该表格允许使用下拉选择选项选择行优先级。
这是我要构建的基本算法:
1用户使用下拉菜单更改行的优先级(注意:该部分工作正常)
2编辑后的行将根据新的优先级上移到该位置(注意:该部分工作正常)
3所有其他行都将根据已编辑的单元格更改其编号(例如,已编辑的单元格最初为13,并更改为4。我希望旧的4变为5,并且所有5到12的数字都增加1)< / p>
我遇到的问题是,将单元格更改为数字4时,它位于旧数字4之下-因此for循环不起作用。
有人做过类似的事情或有建议吗?
function onEdit(event) {
var activeSheet = SpreadsheetApp.getActiveSheet();
var editedCell = activeSheet.getActiveCell();
var columnToSortBy = 1;
var tableRange = "A2:M22";
if(editedCell.getColumn() == columnToSortBy){
var priority = editedCell.getValue();
var range = activeSheet.getRange(tableRange);
var time = new Date();
time = Utilities.formatDate(time, "GMT", "HH:mm:ss");
var nextCell = editedCell.offset(0, 13);
nextCell.setValue(time);
range.sort({ column: columnToSortBy, ascending: true});
}
}
function rearrangeRows() {
var i;
var ss = SpreadsheetApp.getActiveSheet();
var startRow = 1;
var endRow = ss.getLastRow();
var getRange = ss.getDataRange();
var getRow = getRange.getRow();
var testPriority = 3;
var cell = ss.getRange("A4");
var cellValue = cell.getValue();
if (cellValue > number) {
Logger.log(cellValue);
}
Logger.log(number);
// for(i; i > )
}
答案 0 :(得分:0)
我认为您可以在对电子表格进行排序之前,将类似我下面编写的代码放入onEdit函数中。这将增加所有优先级高于您刚设置的优先级的单元格的值,而忽略您刚刚更改的单元格。降低行的优先级时,可能必须对其稍作调整才能起作用,因为您要降低行的原始优先级与新优先级之间的所有行的优先级。
var endRow = activeSheet.getLastRow();
for (var i = 1; i <= endRow; i ++) {
var currentCell = activeSheet.getRange("A" + i);
if (currentCell.getValue() > priority && i != editedCell.getRow()) {
currentCell.setValue(currentCell.getValue() + 1)
}
}