下面,我写了一个小代码来比较POSIXct输出的结果和打印值。有谁知道为什么循环中的值与打印值或 x 变量不同?
timezones <- data.frame(dst_start= '2012-03-11 3:00', TZname='America/Vancouver')
timezones$TZname <- as.character(timezones$TZname)
# Initialize the column
timezones$ET_DST_start <- .POSIXct(1)
timezones$ET_DST_start[1] <- as.POSIXct(timezones$dst_start[1], tz=timezones$TZname[1])
# Assigned value to dataframe
timezones$ET_DST_start[1]
#
as.POSIXct(timezones$dst_start[1], tz=timezones$TZname[1])
# assigned value to a non_initialized variable
x <- as.POSIXct(timezones$dst_start[1], tz=timezones$TZname[1])
x
为什么ET_DST_start值与 x 不同,或者当我直接转换它时?我认为这与初始化列有关,但我不知道为什么会发生这种情况。有什么想法吗?
它确实与初始化列有关。原因是 POSIXct 对象带有时区属性。它不是向量单独元素的属性,而是整个向量的属性。初始化列时,将设置该属性,如果以后更改列的单个元素,则会转换日期以匹配该时区。
您可以看到,您最初使用的时区很重要,如下所示:
# use UTC
timezones$ET_DST_start <- .POSIXct(1, tz = "UTC")
timezones$ET_DST_start[1] <- as.POSIXct(timezones$dst_start[1], tz=timezones$TZname[1])
timezones$ET_DST_start[1]
## [1] "2012-03-11 10:00:00 UTC"
# use CET
timezones$ET_DST_start <- .POSIXct(1, tz = "CET")
timezones$ET_DST_start[1] <- as.POSIXct(timezones$dst_start[1], tz=timezones$TZname[1])
timezones$ET_DST_start[1]
## [1] "2012-03-11 11:00:00 CET"
输出不同,您还可以看到您最初选择的时区已保留。如果覆盖整个列,而不仅仅是其中的一个元素,则会重新设置时区:
# use UTC
timezones$ET_DST_start <- .POSIXct(1, tz = "UTC")
timezones$ET_DST_start <- as.POSIXct(timezones$dst_start[1], tz=timezones$TZname[1])
timezones$ET_DST_start
## [1] "2012-03-11 03:00:00 PDT"
# use CET
timezones$ET_DST_start <- .POSIXct(1, tz = "CET")
timezones$ET_DST_start <- as.POSIXct(timezones$dst_start[1], tz=timezones$TZname[1])
timezones$ET_DST_start
## [1] "2012-03-11 03:00:00 PDT"
在这里,最终结果不取决于时区的初始选择。
示例代码的最后一行对应于相同的情况:您不会将时间戳分配给已预先配置时区的另一个向量,因此不会发生转换。