我试图通过将年,月和日参数提供给new Date()
来获取日期。像这样:
Logger.log(dates[i]);
var date = dates[i].trim();
Logger.log(date);
var dateMDY = date.split("/");
Logger.log(dateMDY);
Logger.log(parseInt(dateMDY[2], 10));
Logger.log(parseInt(dateMDY[0], 10));
Logger.log(parseInt(dateMDY[1], 10));
var finalDate = new Date(parseInt(dateMDY[2]), parseInt(dateMDY[0])-1, parseInt(dateMDY[1]));
Logger.log(finalDate);
这是日志输出:
[16-09-12 09:57:57:047 PDT] 09/24/2016
[16-09-12 09:57:57:048 PDT] 09/24/2016
[16-09-12 09:57:57:048 PDT] [09, 24, 2016]
[16-09-12 09:57:57:049 PDT] 2016.0
[16-09-12 09:57:57:050 PDT] 9.0
[16-09-12 09:57:57:050 PDT] 24.0
[16-09-12 09:57:57:051 PDT] Wed Dec 31 19:00:00 GMT-05:00 1969
[16-09-12 09:57:57:711 PDT] 09/28/2016
[16-09-12 09:57:57:712 PDT] 09/28/2016
[16-09-12 09:57:57:712 PDT] [09, 28, 2016]
[16-09-12 09:57:57:713 PDT] 2016.0
[16-09-12 09:57:57:713 PDT] 9.0
[16-09-12 09:57:57:714 PDT] 28.0
[16-09-12 09:57:57:715 PDT] Wed Dec 31 19:00:00 GMT-05:00 1969
我做错了什么?!
答案 0 :(得分:6)
问题是parseInt("09")
没有基数。
令人震惊的是,Google Apps脚本中的parseInt
(完全不是JavaScript)仍将字符串中的前导0视为八进制中的0。 (这在JavaScript规范中从未出现过,但有些引擎实现了它;最终它被明确禁止。)当然,八进制没有9
数字,而parseInt
在第一个不可解析的数字处停止解析,如果没有可解析的数字,则返回NaN
。因此parseInt("09")
会返回NaN
,您最终会将其作为月份传递给构造函数(因为NaN - 1
为NaN
)。
如果您指定了十进制基数(您在各个部分的Logger.log
语句中执行了此操作,但在实际构建日期时却没有!),它会将"09"
解析为9
:
Logger.log(dates[i]);
var date = dates[i].trim();
Logger.log(date);
var dateMDY = date.split("/");
Logger.log(dateMDY);
Logger.log(parseInt(dateMDY[2], 10));
Logger.log(parseInt(dateMDY[0], 10));
Logger.log(parseInt(dateMDY[1], 10));
var finalDate = new Date(parseInt(dateMDY[2], 10), parseInt(dateMDY[0], 10)-1, parseInt(dateMDY[1], 10));
// -----------------------------------------^^^^----------------------^^^^-------------------------^^^^
Logger.log(finalDate);
输出:
[16-09-12 19:02:15:137 BST] 09/24/2016 [16-09-12 19:02:15:138 BST] [09, 24, 2016] [16-09-12 19:02:15:138 BST] 2016.0 [16-09-12 19:02:15:139 BST] 9.0 [16-09-12 19:02:15:140 BST] 24.0 [16-09-12 19:02:15:140 BST] Sat Sep 24 00:00:00 GMT+01:00 2016
(通过逐步调试GAS调试器中的代码来计算出来。)