尝试创建一个允许使用下拉选择选项选择行优先级的Google表格。
这是我想要构建的基本算法:
1用户使用下拉列表更改行的优先级(注意:该部分工作正常)
2编辑的行将根据新的优先级向上移动到位置(注意:该部分工作正常)
3所有其他行将根据编辑的单元格更改其编号(即Say,编辑的单元格最初为13并更改为4.我希望旧的4变为5,所有从5到12的变量增加1)
我遇到的问题是当单元格变为数字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 > )
}
在您对电子表格进行排序之前,我认为您可以将类似我在下面编写的代码放在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)
}
}