Repita los valores al fusionar los datos de XTS
Pregunta
Si una de mis tablas tiene múltiples valores para la marca de tiempo y la otra, solo una, ¿puedo repetir el valor del elemento único en los valores múltiples?
Por ejemplo:
XTS_A:
2011/01/01 10:00:00,Bar
2011/01/01 10:00:01,Baz
XTS_B:
2011/01/01 10:00:00,A
2011/01/01 10:00:00,B
2011/01/01 10:00:00,C
2011/01/01 10:00:01,B
Merge_Result:
2011/01/01 10:00:00,A,Bar
2011/01/01 10:00:00,B,Bar
2011/01/01 10:00:00,C,Bar
2011/01/01 10:00:01,B,Baz
Ejemplo reproducible:
library(zoo)
library(xts)
XTS_A <- structure(c("Bar", "Baz"), .Dim = c(2L, 1L), index = structure(c(1293894000, 1293894001), tzone = "", tclass = c("POSIXt", "POSIXct")), class = c("xts", "zoo"), .indexCLASS = c("POSIXt", "POSIXct"), .indexTZ = "")
XTS_B <- structure(c("A", "B", "C", "B"), .Dim = c(4L, 1L), index = structure(c(1293894000, 1293894000, 1293894000, 1293894001), tzone = "", tclass = c("POSIXt", "POSIXct")), class = c("xts", "zoo"), .indexCLASS = c("POSIXt", "POSIXct"), .indexTZ = "")
Solución
¿Qué tal solo llenarse después? Ejemplo algo feo (usa un bucle, pero difícil de evitar con dependencias secuenciales como esta):
mrg <- merge(XTS_A,XTS_B)
for(r in seq(nrow(mrg)) ) {
if(is.na(mrg[r,1])) {
mrg[r,1] <- mrg[r-1,1]
}
}
> mrg
XTS_A XTS_B
2011-01-01 16:00:00 "Bar" "A"
2011-01-01 16:00:00 "Bar" "B"
2011-01-01 16:00:00 "Bar" "C"
2011-01-01 16:00:01 "Baz" "B"
La sugerencia de Joran guarda la escritura utilizando la función de relleno del paquete de zoológico:
mrg[,1] <- na.locf(as.vector(mrg$XTS_A))
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow