- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在将 POSIXct 转换为字符并返回到 R 中的 POSIXct 时遇到问题。我运行以下代码:
time_seq_01 <- seq(as.POSIXct("2012-10-28 02:00:00"), by = 900, length.out = 10)
time_seq_02 <- as.character(time_seq_01)
time_seq_03 <- as.POSIXct(time_seq_02)
time_seq_01 <- seq(as.POSIXct("2012-10-28 02:00:00"), by = 900, length.out = 10)
time_seq_02 <- format(time_seq_01,usetz = TRUE)
time_seq_03 <- as.POSIXct(time_seq_02)
time_seq_01
[1] "2012-10-28 02:00:00 CEST" "2012-10-28 02:15:00 CEST"
[3] "2012-10-28 02:30:00 CEST" "2012-10-28 02:45:00 CEST"
[5] "2012-10-28 02:00:00 CET" "2012-10-28 02:15:00 CET"
[7] "2012-10-28 02:30:00 CET" "2012-10-28 02:45:00 CET"
[9] "2012-10-28 03:00:00 CET" "2012-10-28 03:15:00 CET"
time_seq_02
[1] "2012-10-28 02:00:00 CEST" "2012-10-28 02:15:00 CEST"
[3] "2012-10-28 02:30:00 CEST" "2012-10-28 02:45:00 CEST"
[5] "2012-10-28 02:00:00 CET" "2012-10-28 02:15:00 CET"
[7] "2012-10-28 02:30:00 CET" "2012-10-28 02:45:00 CET"
[9] "2012-10-28 03:00:00 CET" "2012-10-28 03:15:00 CET"
time_seq_03
[1] "2012-10-28 02:00:00 CEST" "2012-10-28 02:15:00 CEST"
[3] "2012-10-28 02:30:00 CEST" "2012-10-28 02:45:00 CET"
[5] "2012-10-28 02:00:00 CEST" "2012-10-28 02:15:00 CEST"
[7] "2012-10-28 02:30:00 CEST" "2012-10-28 02:45:00 CET"
[9] "2012-10-28 03:00:00 CET" "2012-10-28 03:15:00 CET"
time_seq_01
),也可以转换为字符(
time_seq_02
)。但是,从字符返回到 POSIXct 的转换会产生错误的时区 (CET/CEST) 值 (
time_seq_03
)。当对这些元素进行排序时,可以清楚地看到这一点:
sort(time_seq_01)
[1] "2012-10-28 02:00:00 CEST" "2012-10-28 02:15:00 CEST"
[3] "2012-10-28 02:30:00 CEST" "2012-10-28 02:45:00 CEST"
[5] "2012-10-28 02:00:00 CET" "2012-10-28 02:15:00 CET"
[7] "2012-10-28 02:30:00 CET" "2012-10-28 02:45:00 CET"
[9] "2012-10-28 03:00:00 CET" "2012-10-28 03:15:00 CET"
sort(time_seq_03)
[1] "2012-10-28 02:00:00 CEST" "2012-10-28 02:00:00 CEST"
[3] "2012-10-28 02:15:00 CEST" "2012-10-28 02:15:00 CEST"
[5] "2012-10-28 02:30:00 CEST" "2012-10-28 02:30:00 CEST"
[7] "2012-10-28 02:45:00 CET" "2012-10-28 02:45:00 CET"
[9] "2012-10-28 03:00:00 CET" "2012-10-28 03:15:00 CET"
Windows 7 64bit
R version 2.15.1 (2012-06-22)
Platform: x86_64-pc-mingw32/x64 (64-bit)
locale:
[1] LC_COLLATE=German_Austria.1252 LC_CTYPE=German_Austria.1252
[3] LC_MONETARY=German_Austria.1252 LC_NUMERIC=C
[5] LC_TIME=German_Austria.1252
attached base packages:
[1] tools stats graphics grDevices utils datasets methods
[8] base
other attached packages:
[1] pkgtools_0.1-3 roxygen2_2.2.2 digest_0.5.2 rj_1.1.0-4
loaded via a namespace (and not attached):
[1] brew_1.0-6 plyr_1.7.1 rj.gd_1.1.0-1 stringr_0.6.1
最佳答案
这是一个解决方法,来自 POSIXct
至character
返回 POSIXct
保留原来的夏令时状态。
Sys.setenv(TZ='Europe/Berlin') # to reproduce OP's example
time_seq_01 <- seq(as.POSIXct("2012-10-28 02:00:00"), by = 900, length.out = 10)
time_seq_02 <- format(time_seq_01,usetz = TRUE)
time_seq_02_lt <- as.POSIXlt(time_seq_02)
time_seq_02_lt$isdst <- as.POSIXlt(time_seq_01)$isdst
time_seq_03 <- as.POSIXct(time_seq_02_lt)
关于r - R 中的字符 POSIXct 转换会导致夏令时转换 (CEST/CET) 时区值错误),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13156836/
举个例子,让我们使用以下 cron 表达式:“0 0 14 1 * ?” -> 在每月第一天的 14:00 触发。 我使用 Quartz CronScheduleBuilder 来构建表达式,但这无关
由于某种原因,夏令时开始时,我的一个网站在午夜 12:00 自动发布,从晚上 11:00 开始发布。有什么方法可以设置 MySQL 服务器变量以正确处理夏令时更改吗? 最佳答案 请提供... SHOW
如何检查夏令时是否生效? 最佳答案 您可以使用time.localtime并查看返回值中的 tm_isdst 标志。 >>> import time >>> time.localtime() (201
我有一个奇怪的问题: 我从 mysql 数据库中获取一些数据,我将这些数据用 strotime 转换为时间戳。然后我将这些时间戳与 for 循环进行比较: for ($i=$start;$imodif
如何检查夏令时是否有效? 最佳答案 您可以使用 time.localtime并查看返回值中的 tm_isdst 标志。 >>> import time >>> time.localtime() (20
我使用以下代码在文件中生成日期: echo "DTSTART;TZID=" . date_default_timezone_get() . ":" . strftime('%Y%m%d', strto
在下面,为什么 to_char() 中不包含夏令时?我怎样才能获得夏令时的时间? SELECT systimestamp AT TIME ZONE 'Australia/Adelaide' from
以下是连续两天之间的小时数计算: (AbsoluteTime[{2011, 3, 14}] - AbsoluteTime[{2011, 3, 13}]) / 3600 因此,您可能不会对 Mathem
function DateTimeToFileTime(FileTime: TDateTime): TFileTime; var LocalFileTime, Ft: TFileTime; S
我制作了一个小代码片段。告诉你几岁,精确到秒。 但是我发现了一些奇怪的事情。我知道时间和时区是工作的噩梦,但这是在我自己的国家和时区内,所以我有点困惑。 如果我输入日期。 27-12-2013(dd-
在 Jenkins 的夜间构建中,我们的一项测试在凌晨 2:00:12 失败。经过一段时间的调试和更改计算机的系统时间后,我感到非常困惑。然后我写了下面的测试(模拟问题),它失败了,但我不明白为什么。
linux如何处理夏令时(DST) 切换是否立即发生,例如 3 点钟立即切换到 2 点钟?或者变化缓慢我问你这个是因为我的服务器上有很大的日期基础,如果这个切换在数据库中的条目上立即发生一小时,将会
我正在使用 NSDate 格式化程序从 Facebook Graph API 请求(格林威治标准时间)获取日期并将其转换为用户的本地时区。我可以很好地读取日期并设置它的新时区,但是当我打印出新日期时,
我的 API 使用 ISO 8601 向客户端表示时间。我们有一个功能,我们希望显示它来自哪个时区。通过纯粹存储时区偏移,我们正在失去对细节的跟踪。 即,犹他州和亚利桑那州遵守 MST -06:00半
PHP代码 $t = strtotime( '2012-09-21T03:00:00+00:00 America/Chicago' ); $t2 = date('c',$t); echo $t2;
PHP代码 $t = strtotime( '2012-09-21T03:00:00+00:00 America/Chicago' ); $t2 = date('c',$t); echo $t2;
我有这个问题。我有这个格式的日期 var datestring = "2017-10-30T15:03:10.933044Z"; 如果我这样写代码 var d = new Date(datestrin
每当日光切换发生时,我都会触发事件。 我知道何时会发生 Spring /秋季切换 TimeZone.CurrentTimeZone.GetDaylightChanges(year) 这会返回 2 个日
我正在开发一个关心夏令时变化的关键应用程序。 我试图通过比较跨越夏令时变化的日期来手动模拟运行时可能发生的情况,因此我进行了以下测试。我当前所在的位置是意大利,因此今年从 CEST(中欧夏令时)更改为
我有这个应用程序,它将当前日期与来自 xml 文件的已解析日期进行比较: Date timeDiff = new Date(date.getTime() - new Date().getTime())
我是一名优秀的程序员,十分优秀!