谷歌应用程序脚本 - 指示NaN的createEvent错误

时间:2014-03-20 16:37:16

标签: javascript google-apps-script

任何人都可以帮助我为什么在下面的代码中获得日期的“NaN”?我正在尝试创建一个日历事件,但它一直在Logger.log中显示“NaN”。执行记录显示以下内容;

“执行失败:无法找到方法createEvent(字符串,数字,数字)。(第38行,文件”代码“)”

这是代码的一部分。该脚本基于两个日期的表单提交运行。该脚本从电子表格中获取值。例如,两个日期可能是2014年4月1日和2014年4月2日。

以下是代码:

        var ptoCalendar = CalendarApp.getCalendarById("ENTER CALENDAR ID")

    var startDate = Utilities.formatDate(new Date(sheet.getRange(i,j-3,1,1).getValue()), 'GMT', "yyyy-MM-dd'T'HH:mm:ss");
    var cnvtStartDate = new Date(startDate).setHours(08,00,00);
    Logger.log(cnvtStartDate);

    var endDate = Utilities.formatDate(new Date(sheet.getRange(i,j-2,1,1).getValue()), 'GMT', "yyyy-MM-dd'T'HH:mm:ss");
    var cnvtEndDate = new Date(endDate).setHours(17,00,00);
    Logger.log(cnvtEndDate);        

    var createEvent = ptoCalendar.createEvent(recipientName+'- PTO', cnvtStartDate, cnvtEndDate);

感谢任何帮助..

Serge响应之前的更新代码 - 我的解决方案。注意:我在这里提供完整的功能,就像以前一样只是一个片段

//This takes the date string from managersDecission() and covnerts back to a date type
function parseDate(dateString){
var time = Date.parse(dateString);
if(!time){
    time = Date.parse(dateString.replace("'T'"," "));
    if(!time){
        bound = dateString.indexOf('T');
        var dateData = dateString.slice(0, bound).split('-');
        var timeData = dateString.slice(bound+1, -1).split(':');

        time = Date.UTC(dateData[0],dateData[1]-1,dateData[2],timeData[0],timeData[1],timeData[2]);
    }
}
return new Date(time);
}

//Used to update the employee requested PTO in the request spreadsheet with managers decision
function managersDecission() {
//Section get the tracking spreadsheet and its values & requests the decision made by manager in grabRequestID()  
  var ss = SpreadsheetApp.openById(trackingSS)
  var sheet = ss.getSheetByName('Requests');
  var data = sheet.getDataRange().getValues();
  var decision = grabRequestID();

//for loop to set the decision of the manager for tracking  
  for (var i=0; i < data.length; i++) {
    for (var j=0; j < data[i].length; j++) {      
      if (data[i][j] == decision[0] && decision[1] == "Approved") {
    sheet.getRange(i+1,j+3,1,1).setValue(decision[1]);
    var recipientEmail = sheet.getRange(i+1,j,1,1).getValue();
    var recipientName = sheet.getRange(i+1,j-1,1,1).getValue();

//This section creates the calendar event for approved PTO        
    var ptoCalendar = CalendarApp.getCalendarById('CALENDAR ID')        
    var startDate = Utilities.formatDate(new Date(sheet.getRange(i+1,j-3,1,1).getValue()), 'GMT', "yyyy-MM-dd'T'HH:MM:SS");
//Debug Line
//Logger.log("start date is "+startDate)  
    var cnvtStartDate = parseDate(startDate);
//Debug Line
//Logger.log("parsed start date "+cnvtStartDate);
    var setHourStartDate = cnvtStartDate.setHours(08,00,00,00);
//Debug Line
//Logger.log("start Hours set "+setHourStartDate);        
    var endDate = Utilities.formatDate(new Date(sheet.getRange(i+1,j-2,1,1).getValue()), 'GMT', "yyyy-MM-dd'T'HH:MM:SS");
//Debug Line
//Logger.log("end date is "+endDate);
    var cnvtEndDate = parseDate(endDate);
//Debug Line
//Logger.log("parse end date "+cnvtEndDate);
    var setHourEndDate = cnvtEndDate.setHours(15,00,00,00);
//Debug Line
//Logger.log("end Hours set "+setHourEndDate);        
    var createEvent = ptoCalendar.createEvent(recipientName+'- PTO', cnvtStartDate, cnvtEndDate);

为下面的评论添加日志信息

[14-03-20 16:08:05:541 PDT] start date is 2014-03-31T07:03:00
[14-03-20 16:08:05:545 PDT] parsed start date Mon Mar 31 2014 00:03:00 GMT-0700 (PDT)
[14-03-20 16:08:05:545 PDT] start Hours set 1396278000000
[14-03-20 16:08:05:546 PDT] end date is 2014-04-02T07:04:00
[14-03-20 16:08:05:547 PDT] parse end date Wed Apr 02 2014 00:04:00 GMT-0700 (PDT)
[14-03-20 16:08:05:547 PDT] end Hours set 1396476000000

根据表示cnvtStartDate是日期对象的Serge评论更新了一些测试

我删除了Utilities.formatDate,实际上从电子表格中提取的值是一个日期值,并允许脚本成功运行。问题是在上午12:00创建日历事件。由于这应该会阻止整个工作日(PTO日),我需要设置一些开始/结束时间。

现在运行脚本并使用以下内容:

var startDate =new Date(sheet.getRange(i+1,j-3,1,1).getValue());
var setHourStartDate = startDate.setHours(08,00,00,00);
var endDate = new Date(sheet.getRange(i+1,j-2,1,1).getValue());
var setHourEndDate = cnvtEndDate.setHours(15,00,00,00);
var createEvent = ptoCalendar.createEvent(recipientName+'- PTO', setHourStartDate, setHourEndDate);

以下错误正在给出。它认为ssetHourStartDate和end是一个数字??

“执行失败:无法找到方法createEvent(字符串,数字,数字)。”

然后我将代码调整为以下内容:

    var startDate =new Date(sheet.getRange(i+1,j-3,1,1).getValue());
    var setHourStartDate = new Date(startDate.setHours(08,00,00,00));
    var endDate = new Date(sheet.getRange(i+1,j-2,1,1).getValue());
    var setHourEndDate = new Date(endDate.setHours(17,00,00,00));   

    var createEvent = ptoCalendar.createEvent(recipientName+'- PTO', setHourStartDate, setHourEndDate);

一切运转良好。它将创建一整天的单日活动或跨越日历顶部的多天。

感谢Serge一如既往地指出事情......

1 个答案:

答案 0 :(得分:1)

为什么你首先使用Utilities.formatDate

如果工作表中的单元格是您不需要将其转换为字符串的日期,请按原样使用它。

如果您真的想以这种方式使用它,请使用如下所示的正确语法:

  var cnvtStartDate = new Date("2014/03/20"):// I replaced with the string "as it should be"
  cnvtStartDate.setHours(8,0,0,0);
  Logger.log(cnvtStartDate);// this is a date object

enter image description here