Come fare il seguito (semplice utilizzando sqldf) utilizzando data.table e ottenere esattamente lo stesso risultato:Come eseguire il join su intervalli di date utilizzando 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")
Questo risolve il problema? http://stackoverflow.com/questions/5123197/matching-time-a-time-in-the-interval-between-a-start-and-end-time –
@DavidRobinson Grazie. Ho effettivamente visto questa domanda e risposta, ma sfortunatamente il mio volume di dati è enorme e preferirei davvero una soluzione veloce data.table ... – Samo
So che questo è un po 'irrealizzato, ma sono l'unico a ricevere il Dec-31-1969 date? Non dovrebbe essere jan-1-1970? –