【问题标题】:DST problems with Google Apps Script and Google calendarGoogle Apps 脚本和 Google 日历的 DST 问题
【发布时间】:2019-07-05 07:32:35
【问题描述】:

我正在创建一个管理课程的学校项目,我遇到了时区问题,这里是我的代码:

javascript
dejt = new Date(thisYear, 8, day, beginTime, endTime, 0, 0);
dejt.toLocaleString("en-US", {timezone: "Europe/Belgrade"});

我通过一些函数直到:

javascript
function makeCalendar(name, begin, end, calendar) {
    var eventSeries = CalendarApp.getCalendarById(calendar).createEventSeries(
        name,
        begin,
        end,
        CalendarApp.newRecurrence()
            .addWeeklyRule().interval(2).until(endDate)
    );
}

直到 10 月 29 日,一切都提前一小时移动。

如何管理夏令时?

编辑:

将脚本设置为 GMT(无夏令时)后,事情变得更加一致,每个日期都变为 +00:00

Logs:
[19-02-12 11:30:15:809 CET] Sun Feb 17 00:00:00 GMT+00:00 2019
[19-02-12 11:30:15:810 CET] Mon Feb 18 00:00:00 GMT+00:00 2019
[19-02-12 11:30:24:051 CET] Mon Sep 03 14:00:00 GMT+00:00 2018
[19-02-12 11:30:24:503 CET] Mon Sep 03 14:50:00 GMT+00:00 2018

现在唯一的问题是重复事件只是改变了夏令时的时间(不是新错误,以前是这样的)。

编辑:

我发现的新东西: 如果您手动编辑事件,则会出现时区框;我的脚本使它成为UTC,但我可以手动编辑或删除它。这里的问题是我需要手动完成。

我还在 Google 文档中找到了 .setTimeZone(string): herehere

现在的问题是我无法让它工作,无论我尝试什么事件都会和 UTC 一样

【问题讨论】:

  • 您能分享一下您是如何将开始日期和结束日期传递给makeCalendar 的吗?在我的情况下,var beginDate = new Date(thisYear, 8, day, beginTime, 0, 0, 0); var endDate = new Date(thisYear, 8, day, endTime, 0, 0, 0); 很好,DST 没有问题
  • 路过的很多,有兴趣我可以提供整个代码
  • 是的,我认为这可能会有所帮助
  • 我用代码编辑了帖子
  • 谢谢!实际上,是的,事情是关于我的脚本的时区,而不是关于你的完整代码(可能你可以从帖子中删除它)。看起来我想出了一个解决方案,请参阅下面的答案

标签: javascript datetime google-apps-script google-calendar-api dst


【解决方案1】:

好的,在深入研究之后,看起来有类似解决方案的东西。

Google 日历将查看脚本的时区,除非它在您传递给它的 Date 对象中指定。在您的情况下,它不是(toLocaleString 不会修改原始对象,如果会,您将在将字符串传递给createEventSeries 时遇到错误)。反正你脚本的时区好像是贝尔格莱德,还有夏令时、时间变化等等。

最后,可能的解决方案。我不知道日历服务是否允许不考虑夏令时,所以试图解决这个问题:

// function to convert date to UTC so that it retains original hours value
function convertDateToUTC(date, timezoneOffset) { 
    return new Date(date.getUTCFullYear(), date.getUTCMonth(), date.getUTCDate(), date.getUTCHours() + timezoneOffset, date.getUTCMinutes(), date.getUTCSeconds()); 
}
// 1 is the timezone offset from GMT
makeCalendar('test event', convertDateToUTC(beginDate, 1), convertDateToUTC(endDate, 1), calendar.getId());

函数convertDateToUTC基于this answer

使用这个,我得到了(开始时间最初是早上 7 点):

【讨论】:

  • 它仍然不起作用日志:[19-02-12 11:26:57:824 CET] Sun Feb 17 01:00:00 GMT+01:00 2019 [19-02-12 11:26:57:825 CET] 2 月 18 日星期一 01:00:00 GMT+01:00 2019 [19-02-12 11:27:05:309 CET] 9 月 3 日星期一 16:00:00 GMT+02: 2018 年 00 月 [19-02-12 11:27:05:743 CET] 9 月 3 日星期一 16:50:00 GMT+02:00 2018
  • 还是老办法:10 月 29 日之前的时间是正确的,之后 - 早一小时?日志中的日期,与您预期的有何不同?
  • 这是同样的问题,但现在每个日期都有相同的偏移量,在此日期之前无论我做什么都有不同的偏移量,这对于处理中断的代码的不同部分很重要
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-05-11
  • 2014-11-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多