Добавление дней к дате-скрипт Google

Я не могу понять, как добавить дни к дате из Google листов в Google Script.

for (var i = 0; i < data.length; ++i) {
    var row = data[i];
    var car = row[1];
    var date = row[2];

if ((car == "Car1") || (car == "Car2")) {
        var newDay = new Date(date + 154);
        Logger.log(newDay);
}

Я пробовал использовать new Date(date.add({days: 154})); но это вызывает ошибку о не поиске add() в объекте.

Я думал, что это может быть проблемой форматирования, в листах формат 7/26/2014.

1 ответов


есть, вероятно, много способов сделать это, вот 2 из них

  1. зная, что собственное значение даты JavaScript составляет миллисекунды, вы можете добавить n умножить 3600000*24 миллисекунд на это собственное значение,n - количество дней.
  2. или вы можете получить значение Дня, добавьте n к этому значению и перестроить дату с этим. Чтобы получить день, просто используйте getDate(). См. doc на JS date здесь.

ниже просто демонстрационная функция, которая использует оба метода и показывает результаты в регистраторе:

function myFunction() {
  var data = SpreadsheetApp.getActive().getActiveSheet().getDataRange().getValues();
  for (var i = 0; i < data.length; ++i) {
    var row = data[i];
    var car = row[1];
    var date = new Date(row[2]); // make the sheet value a date object
    Logger.log('original value = '+date);
    Logger.log('method 1 : '+new Date(date.getTime()+5*3600000*24));
    Logger.log('method 2 : '+new Date(date.setDate(date.getDate()+5)));
  }
}

enter image description here