【问题标题】:Google Spread Sheet Script. Working with Dates谷歌电子表格脚本。使用日期
【发布时间】:2017-11-28 04:29:49
【问题描述】:

我正在使用 Google Apps 脚本阅读包含 DateTime 的 Google Sheet 单元格列表。 单元格中的值为:

A1:7月26日13:00

A2:7 月 27 日 0:00

var dateValues = SpreadsheetApp.getActiveSheet().getRange("A1:A2").getValues(); 

但是,读取的值晚了 1 小时。这是我在调试器中看到的:

dateValues[0] = 2017 年 7 月 26 日星期三 12:00:00 GMT+0200 (EET)

dateValues[1] = 2017 年 7 月 26 日星期三 23:00:00 GMT+0200 (EET)

我想这是一个时区问题,但我不太了解这个概念。 我的时区是当前(由于 DTS)GMT + 3。实际上,在 DTS 期间之外,它是 GMT +2。电子表格时区是耶路撒冷 GMT+2。

EET - 不要低估使用它的原因。

基本上,我希望将工作表中的值输入代码。

什么是概念?

【问题讨论】:

  • 在电子表格本身中,在文件->电子表格设置下,时区设置为?
  • @Karl_S 耶路撒冷 GMT + 2
  • 你能把它改成你的时区,看看你得到了什么?
  • @Karl_S 也许我不够清楚。对不起。这是我的时区。

标签: google-sheets formulas


【解决方案1】:

有两种方法可以解决这个问题

  1. 使用 getDisplayValues() 而不是 getValues()。这将强制进行一些转换,因为 getDisplayValues() 返回字符串而不是日期

  2. 使您的脚本编辑器时区与工作表 tz 匹配。 在我的情况下,工作表是(GMT+2 耶路撒冷),但由于某种原因,脚本编辑器不同(GMT+2 莫斯科)。 设置脚本编辑器TZ,解决了问题。

【讨论】:

    猜你喜欢
    • 2013-03-31
    • 1970-01-01
    • 2021-04-12
    • 1970-01-01
    • 2012-06-15
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多