【问题标题】:Splitting up unusual date & time column format in R在 R 中拆分不寻常的日期和时间列格式
【发布时间】:2016-09-13 23:02:29
【问题描述】:

这可能是一个微不足道的问题,但我试图在包含 140 万行的 GPS 数据帧上将日期和时间分解为它们自己的变量。来自at的时间戳是:

2015-11-19T03:27:56

我已经能够毫无问题地提取日期,但是在尝试提取时间时,“T”会出现问题。以下代码:

sater001$utc_d <- as.Date(sater001$utc_time_stamp) 

'sater001$utc_d' 是我的数据框,'utc_time_stamp' 是我希望拆分的变量,日期提取得很好。

但正在运行:

sater001$utc_t <- format(as.POSIXlt(sater001$utc_time_stamp) ,format = "T%H:%M:%S") 

给我一​​个充满T00:00:00 值的列。

我在这里缺少什么?

【问题讨论】:

  • lubridate::ymd_hms('2015-11-19T03:27:56') 工作正常。要提取时间,format(lubridate::ymd_hms('2015-11-19T03:27:56'), '%T')(或%H:%M:%S)。

标签: r date time split format


【解决方案1】:

我们还需要在格式中包含T

v2 <- as.POSIXct(v1, format = '%Y-%m-%dT%H:%M:%S')
v2
#[1] "2015-11-19 03:27:56 IST"

现在,我们可以提取hms 部分

format(v2, "%H:%M:%S")

注意:我们不需要任何额外的包来获得预期的结果。

数据

v1 <- "2015-11-19T03:27:56"

【讨论】:

  • 这解决了我的问题。在将列拆分为单独的数据和时间变量之前,我能够将时间转换为这种建议的格式。谢谢你的帮助,朋友。我真的很感激。
猜你喜欢
  • 2021-10-30
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多