Jak zrobić poniżej (proste korzystając sqldf) używając data.table i uzyskać dokładnie taki sam wynik:Jak wykonać łączenie w zakresie dat za pomocą data.table?
library(data.table)
whatWasMeasured <- data.table(start=as.POSIXct(seq(1, 1000, 100),
origin="1970-01-01 00:00:00"),
end=as.POSIXct(seq(10, 1000, 100), origin="1970-01-01 00:00:00"),
x=1:10,
y=letters[1:10])
measurments <- data.table(time=as.POSIXct(seq(1, 2000, 1),
origin="1970-01-01 00:00:00"),
temp=runif(2000, 10, 100))
## Alternative short names for data.tables
dt1 <- whatWasMeasured
dt2 <- measurments
## Straightforward with sqldf
library(sqldf)
sqldf("select * from measurments m, whatWasMeasured wwm
where m.time between wwm.start and wwm.end")
Czy to rozwiązuje twój problem? http://stackoverflow.com/questions/5123197/matching-time-a-time-in-interval-between-a-start-and-end-time –
@DavidRobinson Dzięki. Właściwie to widziałem to pytanie i odpowiedź, ale niestety mój wolumen danych jest ogromny i wolałbym, aby szybkie rozwiązanie data.table ... – Samo
Wiem, że to trochę nierealne, ale jestem jedynym, który dostał Dec-31-1969 Daktyle? Czy nie powinno to być jan-1-1970? –