繁体   English   中英

如何将数据框中的日期转换为Date数据类型?

[英]How to convert dates in a dataframe to a Date datatype?

我已将一个日期值导入R:

dtime <- read.csv("dtime.csv", header=TRUE)

输出(2013年11月7日)打印为:

> dtime
              Date
1 07-11-2013 23:06

而且它的类别是“因素”。

> class(dtime$Date)
[1] "factor" 

现在,我想从数据中提取时间详细信息(小时,分钟,秒)。 因此,我试图将数据框的日期值转换为Date类型。 但是以下命令均无效:

dtime <- as.Date(as.character(dtime),format="%d%m%Y")

unclass(as.POSIXct(dtime))

as.POSIXct(dtime$Date, format = "%d-%m-%Y %H:%M:%S")

我如何在R中实现这一目标???

您的尝试不起作用,因为指定的格式错误。

使用base R可以使用as.POSIXlt解决此问题的两种方法

Res <- as.POSIXlt(dtime$Date,  format = "%d-%m-%Y %H:%M")
Res$hour
Res$min

另外,有关更多选项,请参见

attr(Res, "names")
## [1] "sec"    "min"    "hour"   "mday"   "mon"    "year"   "wday"   "yday"   "isdst"  "zone"   "gmtoff"

或使用as.POSIXct不太方便

Res2 <- as.POSIXct(dtime$Date,  format = "%d-%m-%Y %H:%M")
format(Res2, "%H") # returns a character vector
format(Res2, "%M") # returns a character vector

我想贡献使用lubridate解决方案:

dates <- c("07-11-2013 23:06", "08-10-2012 11:11")
dta <- data.frame(dates)
require(lubridate)
dta$properDate <- dmy_hm(dta$dates)

如果需要, lubridate将使您能够方便地指定时区或提取其他信息

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM