Datas/tempos de compreensão (Posixc e Posixct) em R
Pergunta
Estou lendo uma tabela e contém cordas que descrevem registros de data e hora. Eu só quero converter de string para um tipo de dateTime embutido ...
R> Q <- read.table(textConnection('
tsstring
1 "2009-09-30 10:00:00"
2 "2009-09-30 10:15:00"
3 "2009-09-30 10:35:00"
4 "2009-09-30 10:45:00"
5 "2009-09-30 11:00:00"
'), as.is=TRUE, header=TRUE)
R> ts <- strptime(Q$tsstring, "%Y-%m-%d %H:%M:%S", tz="UTC")
Se eu tentar armazenar a coluna DateTime no Data.Frame, recebo um erro curioso:
R> Q$ts <- ts
Error in `$<-.data.frame`(`*tmp*`, "ts", value = list(sec = c(0, 0, 0, :
replacement has 9 rows, data has 5
Mas se eu passar por uma representação numérica realizada no Data.Frame, ele funciona ...
R> EPOCH <- strptime("1970-01-01 00:00:00", "%Y-%m-%d %H:%M:%S", tz="UTC")
R> Q$minutes <- as.numeric(difftime(ts, EPOCH, tz="UTC"), units="mins")
R> Q$ts <- EPOCH + 60*Q$minutes
Alguma ajuda para entender a situação?
Solução
strptime
classe de retorno POSIXlt
, você precisa POSIXct
No quadro de dados:
R> class(strptime("2009-09-30 10:00:00", "%Y-%m-%d %H:%M:%S", tz="UTC"))
[1] "POSIXt" "POSIXlt"
R> class(as.POSIXct("2009-09-30 10:00:00", "%Y-%m-%d %H:%M:%S", tz="UTC"))
[1] "POSIXt" "POSIXct"
Classe POSIXct
representa o número (assinado) de segundos desde o início de 1970 como um vetor numérico. Classe POSIXlt
é uma lista nomeada de vetores que representam Sec, Min, Hour, Mday, Seg, Ano, etc.
R> unclass(strptime("2009-09-30 10:00:00", "%Y-%m-%d %H:%M:%S", tz="UTC"))
$sec
[1] 0
$min
[1] 0
$hour
[1] 10
$mday
[1] 30
$mon
[1] 8
$year
[1] 109
$wday
[1] 3
$yday
[1] 272
$isdst
[1] 0
attr(,"tzone")
[1] "UTC"
R> unclass(as.POSIXct("2009-09-30 10:00:00", "%Y-%m-%d %H:%M:%S", tz="UTC"))
[1] 1.254e+09
attr(,"tzone")
[1] "UTC"
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow