Google电子表格上的时间驱动条件更新

时间:2018-09-13 11:54:17

标签: google-apps-script google-sheets-api google-sheets-macros

我想每周更新一次给定的日期[重设日期]。 在此更新过程中,如果每周出勤率也将重置为0,并且其值小于2,则出勤点数将减少8点。

初始表格示例

Name     |  Attendance Point | Weekly Attendance |  Reset Day
--------------------------------------------------------------
Jack     |         12        |         0         |  13/09/2018
Jacob    |         23        |         0         |
Emily    |         12        |         1         | 
Rick     |         11        |         2         | 
Rob      |         21        |         3         |

所需更新

Name     |  Attendance Point | Weekly Attendance |  Reset Day
--------------------------------------------------------------
Jack     |          4        |         0         |  20/09/2018
Jacob    |         15        |         0         |
Emily    |          4        |         0         | 
Rick     |         11        |         0         | 
Rob      |         21        |         0         |

样本基础表

https://docs.google.com/spreadsheets/d/1khPC5r2p0b1srsEGka3fl-GAl6nHACaVR0Cf31cqA1o/edit?usp=sharing

预先感谢

function resetCells() {
var ss = SpreadsheetApp.getActive().getSheetByName('Sheet');
var range = ss.getDataRange().offset(1, 0, ss.getLastRow() - 1);
var values = range.getValues().map(function(e) {
  return e[0] ? [false, e[1], e[2], e[3], e[4] + 1, e[5]] : e;
});
range.setValues(values);
}

更新功能

function weekDays() {
var ss = SpreadsheetApp.getActive().getSheetByName('Sheet').getRange('F2').setValue(new Date())

}

1 个答案:

答案 0 :(得分:0)

我用这个脚本片段解决了问题

function weekDays() {
  var sd = SpreadsheetApp.getActive().getSheetByName('Sheet').getRange('F2').setValue(new Date())
  var ss = SpreadsheetApp.getActive().getSheetByName('Sheet');
  var range = ss.getDataRange().offset(1, 0, ss.getLastRow() - 1);
  var values = range.getValues().map(function(e) {
    if (Number(e[4]) < 2 && Number(e[2] >= 8) ) {
      return e[1] ? [e[0], e[1], Number(e[2]) - 8, e[3], 0, e[5]] : e;
    } else if (Number(e[4]) < 2 && Number(e[2]) < 8) {
      return e[1] ? [e[0], e[1], 0, e[3], 0, e[5]] : e;
    } else {
      return e[1] ? [e[0], e[1], e[2], e[3], 0, e[5]] : e;  
    }
  }); 
  range.setValues(values);
}