Google表格重新排列行的脚本

问题描述 投票:0回答:1

尝试创建一个允许使用下拉选择选项选择行优先级的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 > )
}
google-apps-script google-sheets google-apps google-sheets-formula
1个回答
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)
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.