我试图通过将年,月和日参数输入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
我究竟做错了什么?!
最佳答案
问题是parseInt("09")
没有基数。
令人震惊的是,Google Apps脚本(不是JavaScript)中的parseInt
仍然将字符串中的前导0视为八进制。 (这从来没有出现在JavaScript规范中,但是某些引擎实现了它;最终它被明确禁止。)当然,八进制没有9
数字,并且parseInt
在第一个不可解析的数字处停止解析,返回如果没有可解析的数字。因此,NaN
返回parseInt("09")
,您最终将其作为月份传递给构造函数(因为NaN
是NaN - 1
)。
如果您指定了十进制基数(您在各个部分的NaN
语句中进行了此操作,但是在实际构建日期时没有这样做!),它将把Logger.log
解析为"09"
:
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] 2016年9月24日
[16-09-12 19:02:15:138 BST] [2016年9月24日]
[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] 2016年9月24日星期六00:00:00 GMT + 01:00
(通过逐步调试GAS调试器中的代码来解决此问题。)