Ich habe ein Datenrahmen, der wie folgtR: Konvertieren Sie mehrere Spalten in einzelne Spalte
+---------+--------+--------+--------+-------+
| ID | week1_t| week1_a| week2_t|week2_a|
+---------+--------+--------+--------+-------+
| 1 | 12 | 22 | 17 | 4 |
| 1 | 15 | 32 | 18 | 5 |
| 1 | 24 | 12 | 29 | 6 |
| 2 | 45 | 11 | 19 | 8 |
| 2 | 23 | 33 | 20 | 10 |
+---------+--------+--------+--------+-------+
Es sind 48 Spalten (Woche 1-24) sieht mit „t“ und „a“ Suffixen. Ich möchte wie diese all Woche Spalten in einen einzigen „Woche“ -Spalte konsolidieren:
+---------+--------+--------+--------
| ID | week | t | a |
+---------+--------+--------+--------
| 1 | 1 | 22 | 17 |
| 1 | 2 | 32 | 18 |
| 1 | 3 | 12 | 19 |
| 1 | 5 | 33 | 20 |
+---------+--------+--------+-------
Wie gehe ich über diese Transformation in R zu machen? Ich kann mir keine Möglichkeit vorstellen, dies außerhalb von mehreren if-Anweisungen und for-Schleifen zu tun.
Daten
dd <- read.table(header = TRUE, text = "ID week1_t week1_a week2_t week2_a
1 12 22 17 4
1 15 32 18 5
1 24 12 29 6
2 45 11 19 8
2 23 33 20 10")
Paket dplyr alle Funktionen, die Sie benötigen hat. Hier ist ein praktischer Spickzettel: https://www.rstudio.com/wp-content/uploads/2015/02/data-wrangling-cheatsheet.pdf –
Bitte zeigen Sie, was Sie versucht haben. und verwende dieses Tabellenformat nicht. – rawr
'reshape (dd, dir = 'lang', variierend = lapply (c ('t', 'a'), grep, namen (dd)), timevar = 'woche')' – rawr