我试图通过将年,月和日参数输入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"),您最终将其作为月份传递给构造函数(因为NaNNaN - 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调试器中的代码来解决此问题。)

10-04 16:09
查看更多