你如何从R中的posixct格式datetime中选择小时,分钟和秒

时间:2013-08-06 14:50:54

标签: r

我有一个这样的数据框:

dput(tail(x,10))
structure(list(DATE = structure(c(1375725600, 1375729200, 1375732800, 
1375736400, 1375740000, 1375743600, 1375747200, 1375750800, 1375754400, 
1375758000), class = c("POSIXct", "POSIXt"), tzone = ""), VOLUME = c(2790797L, 
2670868L, 2586397L, 2470043L, 2336334L, 2228206L, 2129270L, 2032518L, 
872133L, 725377L), PC = c(10.12, 9.95, 9.9, 9.46, 8.99, 8.94, 
9.79, 8.45, 8.85, 8.5)), .Names = c("DATE", "VOLUME", "PC"), row.names = 3399:3408, class = "data.frame")

我需要为时间创建另一个colume,以便我可以在一天中的不同时间之间进行选择。

我试过这个:

x$time<-format(x$DATE, "%H:%M:%S)

没有用,我得到空值。

我也试过这个:

x$t<-strptime(x$DATE, format="%H:%M:%S") 

我得到NA值。我的x $ DATE格式化为POSIXct,任何想法我可能会在这里发生什么?

2 个答案:

答案 0 :(得分:2)

您可以使用lubridate在日期的小时,分​​钟和秒内获取组件:

library(lubridate)
transform(x,time.str = format(DATE,'%H:%M:%S'),
              hour = hour(DATE),
              minute = minute(DATE),
              second= second(DATE))

                    DATE  VOLUME    PC time.str hour minute second
3399 2013-08-05 20:00:00 2790797 10.12 20:00:00   20      0      0
3400 2013-08-05 21:00:00 2670868  9.95 21:00:00   21      0      0
3401 2013-08-05 22:00:00 2586397  9.90 22:00:00   22      0      0
3402 2013-08-05 23:00:00 2470043  9.46 23:00:00   23      0      0
3403 2013-08-06 00:00:00 2336334  8.99 00:00:00    0      0      0
3404 2013-08-06 01:00:00 2228206  8.94 01:00:00    1      0      0
3405 2013-08-06 02:00:00 2129270  9.79 02:00:00    2      0      0
3406 2013-08-06 03:00:00 2032518  8.45 03:00:00    3      0      0
3407 2013-08-06 04:00:00  872133  8.85 04:00:00    4      0      0
3408 2013-08-06 05:00:00  725377  8.50 05:00:00    5      0      0

答案 1 :(得分:-1)

这有效:

x$t<-strftime(x$DATE, format="%H:%M:%S")