3

我真的以为我开始理解它是如何工作的,直到我试图为这个问题提炼一个测试用例并且再次完全困惑。

使用谷歌电子表格,您可以编写如下自定义函数:

function dateToSeconds(date) {
  var hours = date.getHours();
  var minutes = date.getMinutes();
  var seconds = date.getSeconds();
  return (hours*3600) + (minutes*60) + seconds;
}

并通过执行例如在单元格中调用它

=dateToSeconds(A1)

它可以满足您的期望。但是,如果您这样称呼它:

function test() {
    var sheet = SpreadsheetApp.getActiveSheet();

    sheet.getRange("A2").setValue(dateToSeconds(sheet.getRange("A1").getValue()));
}

有25m 21s的差异。有没有搞错?

此外,如果您想从脚本中返回一个日期对象,以便将其格式化为时间,您可以执行例如

function newTime(hours, minutes, seconds) {
    // 1899-12-30 is the epoch for time values, it seems
    // http://stackoverflow.com/questions/4051239/how-to-merge-date-and-time-as-a-datetime-in-google-apps-spreadsheet-script
   return new Date(1899, 11, 30, hours, minutes, seconds, 0);
 }

并通过以下方式调用它:

=newTime(A1, A2, A3)

它工作正常。如果你这样做:

function test() {
    var sheet = SpreadsheetApp.getActiveSheet();
    var values = sheet.getRange("A1:C3").getValues();
    sheet.getRange("D3").setValue(newTime(values[0], values[1], values[2]));
}

然后(给定 11:00:00 的输入)它被格式化为日期,如:

1970 年 1 月 1 日 01:00:00

看起来它被解释为更传统的 1970 年代之后的一个小时?我认为我之前看到的行为与上面的 25m 21s 偏移有点对称,我会看到:

10:34:39

我的测试用例在这里

4

2 回答 2

1

=dateToSeconds() 与 test() 函数的行为似乎确实有些奇怪。看起来有一个错误导致两者之间的时间差异。请在问题跟踪器中提出一个错误。

然而,我能够通过在单元格上使用数字格式来完成这项工作。看看我修改后的电子表格副本。在单元格 A2 中,我输入了“29/04/2012 11:00:00”,然后设置格式 > 数字 > 15:59:00 时间。您也可以使用Range.setNumberFormat ("HH:mm:ss");以编程方式执行此操作。这导致单元格 A2 显示 11:00:00。

然后,我修改了您的测试函数以具有以下代码:

function test() {
  var sheet = SpreadsheetApp.getActiveSheet();

  sheet.getRange("E2").setValue(dateToSeconds(sheet.getRange("A2").getValue()));
  Logger.log(sheet.getRange("A2").getValue());
  Logger.log(sheet.getRange("A2").getNumberFormat());

  var values = sheet.getRange("A4:C4").getValues();
  Logger.log(values[0][0] + " " + values[0][1] + " " + values[0][2]);
  sheet.getRange("E4").setValue(newTime2(values[0][0], values[0][1], values[0][2])).setNumberFormat("HH:mm:ss");
}

而不是 newTime 函数,我使用以下代码创建了一个 newTime2:

function newTime2(hours, minutes, seconds) {
  var date = new Date();
  date.setHours(hours);
  date.setMinutes(minutes);
  date.setSeconds(seconds);
  Logger.log(date);
  return date;
}

我希望这会有所帮助。

于 2012-04-29T15:00:36.410 回答
0

请参阅这篇关于如何获得正确值的帖子,因为电子表格时间和 Java Script 时间不相同,所以有一个校正因子,它们有不同的起点:

GAS:如何从 Google 电子表格中读取正确的时间值

于 2013-07-19T06:01:26.857 回答