R apply() 函数 format() over POSIXct

R apply() function format() over POSIXct

我有一个包含两列的 data.frame

我的数据样本:

UTCTime <- as.POSIXct(c("2018-04-12 17:23:14", "2018-04-12 17:17:14","2018-04-12 07:48:20", "2018-04-12 11:25:04", "2018-04-12 11:24:38"), tz = "UTC")
TimeZone <- c("Europe/Prague", "Europe/Dublin", "Europe/Prague", "Europe/Prague", "Europe/Prague")
df <- cbind.data.frame(UTCTime, TimeZone, stringsAsFactors = FALSE)

df
              UTCTime      TimeZone
1 2018-04-12 17:23:14 Europe/Prague
2 2018-04-12 17:17:14 Europe/Dublin
3 2018-04-12 07:48:20 Europe/Prague
4 2018-04-12 11:25:04 Europe/Prague
5 2018-04-12 11:24:38 Europe/Prague

我想获取本地时区的时间向量。我成功地完成了一行:

> format(df$UTCTime[1], "%Y-%m-%d %H:%M:%S", tz = df$TimeZone[1])
[1] "2018-04-12 19:23:14"

但是,当我尝试将此应用到整个 data.frame 时,出现错误:

> apply(df, 1, function(x) format(x["UTCTime"], "%Y-%m-%d %H:%M:%S", tz = x["TimeZone"]))

 Error in format.default(x["UTCTime"], "%Y-%m-%d %H:%M:%S", tz = x["TimeZone"]) : 
  invalid 'trim' argument 

当我尝试将任何其他函数传递给 apply 时,一切都按预期工作:

> apply(df, 1, function(x) paste(x["UTCTime"], x["TimeZone"]))
[1] "2018-04-12 17:23:14 Europe/Prague" "2018-04-12 17:17:14 Europe/Dublin" "2018-04-12 07:48:20 Europe/Prague"
[4] "2018-04-12 11:25:04 Europe/Prague" "2018-04-12 11:24:38 Europe/Prague"

您可以使用 tidyverse:

df %>% 
  rowwise %>%
  transmute(LocalTime = format(UTCTime, tz = TimeZone))


# A tibble: 5 x 1
  LocalTime          
  <chr>              
1 2018-04-12 19:23:14
2 2018-04-12 18:17:14
3 2018-04-12 09:48:20
4 2018-04-12 13:25:04
5 2018-04-12 06:24:38

唯一的问题是允许时区变化。解决方案:

mapply(df$UTCTime, tz = df$TimeZone, FUN = format)
## [1] "2018-04-12 19:23:14" "2018-04-12 18:17:14" "2018-04-12 09:48:20"
## [4] "2018-04-12 13:25:04" "2018-04-12 13:24:38"