Google表格脚本重新排列行

时间:2019-03-14 14:06:57

标签: google-apps-script google-sheets google-apps google-sheets-formula

尝试创建一个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 > )
}

1 个答案:

答案 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)
    }
}