2013-02-28 20 views
5

Ich habe eine CSV-Datei in folgendem Format:Wie gruppiere ich einen data.frame nach Datum?

Date  ,  Time , Value 
1899-01-01 , 4:00:00 , 1 
1899-01-01 , 4:01:00 , 2 
1899-01-01 , 4:02:00 , 3 
1899-01-01 , 4:03:00 , 4 
1899-01-01 , 4:04:00 , 5 
1900-08-22 , 22:00:00 , 101 
1900-08-22 , 22:01:00 , 102 
2013-08-29 , 4:00:00 , 1000 
2013-02-29 , 4:02:00 , 1001 
2013-02-29 , 4:03:00 , 1002 

Ist es möglich, group by date eine data.table im folgenden Format zu produzieren:

Date  , Vector(variable length) 
1899-02-28, c(1,2,3,4,5) 
1900-08-22, c(101,102) 
1900-08-22, c(1000,1001,1002) 

Dies ist das beste, was ich habe so weit (nach einem Tag der Versuche):

raw <- read.csv(pathName, header = TRUE, stringsAsFactors = FALSE) 
groupedByDate <- split(raw, raw$Date) 

Allerdings scheint dies eine sehr breite Tabelle mit einer Spalte für jeden d zu produzieren gegessen, was nicht sehr nah an dem ist, was ich will.

Antwort

8

über Was aggregate auf einem data.frame namens „mydf“ wie folgt verwendet:

> temp <- aggregate(Value ~ Date, mydf, as.vector) 
> temp 
     Date   Value 
1 1899-01-01 1, 2, 3, 4, 5 
2 1900-08-22  101, 102 
3 2013-02-29  1001, 1002 
4 2013-08-29   1000 

Die Spalte „Wert“ ist nun ein list die Ihre Vektoren enthält.

> temp$Value 
$`0` 
[1] 1 2 3 4 5 

$`1` 
[1] 101 102 

$`2` 
[1] 1001 1002 

$`3` 
[1] 1000 

Was Sie wahrscheinlich wurden mit split suchen ist:

> split(mydf$Value, mydf$Date) 
$`1899-01-01 ` 
[1] 1 2 3 4 5 

$`1900-08-22 ` 
[1] 101 102 

$`2013-02-29 ` 
[1] 1001 1002 

$`2013-08-29 ` 
[1] 1000 
+0

Danke, das absolut brillant funktioniert! Ich werde deine als die Antwort markieren, so wie du es zuerst warst. – Contango

3

Verwenden aggregate und paste0

> aggregate(Value ~ Date, data=DF, FUN=paste0) 
     Date   Value 
1 1899-01-01 1, 2, 3, 4, 5 
2 1900-08-22  101, 102 
3 2013-02-29  1001, 1002 
4 2013-08-29   1000 
+0

Vielen Dank für diese Antwort, sehr geschätzt. p.s. Ich wollte eigentlich einen Zahlenvektor, also sein "c" statt "einfügen". – Contango

Verwandte Themen