2

我遇到了非常奇怪的 strptime 解析行为。

这是我在 Windows 机器上的 R 会话

> R.Version()$version.string
[1] "R version 2.15.2 (2012-10-26)"
> a <- ( strptime(  "29-MAR-13 02.26.53.000000000 AM" , "%d-%B-%y %I.%M.%OS %p" ) )
> str(a)
 POSIXlt[1:1], format: "2013-03-29 02:26:53"
> # convert to double: doesn't work
> as.double(a)
[1] NA
> b <- ( strptime(  "29-MAR-13 04.26.53.000000000 AM" , "%d-%B-%y %I.%M.%OS %p" ) )
> #same as `a`, but another hour
> str(b)
 POSIXlt[1:1], format: "2013-03-29 04:26:53"
> #convert to double: works
> as.double(b)
[1] 1364520413
>  #WTF ???

我已经在另一台具有不同 R 次要版本的机器(linux)上测试了相同的代码。代码在两种情况下都按预期工作:

> R.Version()$version.string
[1] "R version 2.15.1 (2012-06-22)"
> a <- ( strptime(  "29-MAR-13 02.26.53.000000000 AM" , "%d-%B-%y %I.%M.%OS %p" ) )
> str(a)
 POSIXlt[1:1], format: "2013-03-29 02:26:53"
> # convert to double: WORKS!
>  as.double(a)
[1] 1364513213
> b <- ( strptime(  "29-MAR-13 04.26.53.000000000 AM" , "%d-%B-%y %I.%M.%OS %p" ) )
> #same as `a`, but another hour
> str(b)
 POSIXlt[1:1], format: "2013-03-29 04:26:53"
>  #convert to double: works
> as.double(b)
[1] 1364520413
>

有人可以告诉我有什么问题吗?我在 R 中发现了一个错误吗?

4

1 回答 1

3

你在以色列吗?谷歌搜索“夏令时“3 月 29 日”显示,2013 年 DST 于 3 月 29 日在以色列开始,例如http://www.timeanddate.com/worldclock/clockchange.html?n=110 ... 地区/时间的差异您测试的两台计算机之间的区域设置当然可以解释这一点,如果一台设置为以色列时区而另一台则没有。您可以使用tz="GMT"...进行检查

PS:我查看了您的个人资料,发现您确实在以色列。在我最初发布答案之前我没有看!

PPS:关于日期时间转换的很大一部分查询结果是关于时区,特别是夏令时问题,这就是我首先得到答案的原因。

于 2013-07-30T15:06:22.700 回答