Strings nach Gruppe verketten mit dplyr [duplicate]

Diese Frage hat hier bereits eine Antwort:

Zusammenfassen / Verketten / Aggregieren einer Spalte zu einer einzelnen, durch Kommas getrennten Zeichenfolge innerhalb jeder Gruppe 2 Antworten

Ich habe einen Datenrahmen, der so aussieht

> data <- data.frame(foo=c(1, 1, 2, 3, 3, 3), bar=c('a', 'b', 'a', 'b', 'c', 'd'))
> data
  foo bar
1   1   a
2   1   b
3   2   a
4   3   b
5   3   c
6   3   d

Ich möchte eine neue Spalte bars_by_foo erstellen, die die Verkettung der Werte von bar durch foo darstellt. Die neuen Daten sollten also so aussehen:

  foo bar bars_by_foo
1   1   a          ab
2   1   b          ab
3   2   a           a
4   3   b         bcd
5   3   c         bcd
6   3   d         bcd

Ich hatte gehofft, dass das folgende funktionieren würde:

p <- function(v) {
  Reduce(f=paste, x = v)
}
data %>% 
  group_by(foo) %>% 
  mutate(bars_by_foo=p(bar))

Aber dieser Code gibt mir einen Fehler

Error: incompatible types, expecting a character vector.

Was mache ich falsch

Antworten auf die Frage(8)

Ihre Antwort auf die Frage