R有is.vector
,is.list
,is.integer
,is.double
,is.numeric
,is.factor
,is.character
等。为什么没有is.POSIXct
,is.POSIXlt
或is.Date
?
我需要一种可靠的方法来检测POSIXct
对象,而class(x)[1] == "POSIXct"
似乎真的......很脏。
答案 0 :(得分:23)
我个人只会使用inherits
作为joran建议。您可以使用它来创建自己的is.POSIXct
函数。
# functions
is.POSIXct <- function(x) inherits(x, "POSIXct")
is.POSIXlt <- function(x) inherits(x, "POSIXlt")
is.POSIXt <- function(x) inherits(x, "POSIXt")
is.Date <- function(x) inherits(x, "Date")
# data
d <- data.frame(pct = Sys.time())
d$plt <- as.POSIXlt(d$pct)
d$date <- Sys.Date()
# checks
sapply(d, is.POSIXct)
# pct plt date
# TRUE FALSE FALSE
sapply(d, is.POSIXlt)
# pct plt date
# FALSE TRUE FALSE
sapply(d, is.POSIXt)
# pct plt date
# TRUE TRUE FALSE
sapply(d, is.Date)
# pct plt date
# FALSE FALSE TRUE
答案 1 :(得分:17)
lubridate
包具有is.POSIXt
,is.POSIXct
,is.POSIXlt
和is.Date
个功能。
答案 2 :(得分:7)
您可以尝试is()
。这就是lubridate
函数is.Date
和is.POSIX*
依赖的内容。
x <- Sys.time()
class(x)
# [1] "POSIXct" "POSIXt"
is(x, "Date")
#v[1] FALSE
is(x, "POSIXct")
# [1] TRUE
y <- Sys.Date()
class(y)
# [1] "Date"
is(y, "POSIXct")
# [1] FALSE
is(y, "Date")
# [1] TRUE