Die Funktion eatmeines Pakets safejoin hat eine solche Funktion. Wenn Sie ihm eine Liste von data.frames als zweite Eingabe geben, werden sie rekursiv mit der ersten Eingabe verknüpft.
Ausleihen und Erweitern der Daten der akzeptierten Antwort:
x <- data_frame(i = c("a","b","c"), j = 1:3)
y <- data_frame(i = c("b","c","d"), k = 4:6)
z <- data_frame(i = c("c","d","a"), l = 7:9)
z2 <- data_frame(i = c("a","b","c"), l = rep(100L,3),l2 = rep(100L,3)) # for later
# devtools::install_github("moodymudskipper/safejoin")
library(safejoin)
eat(x, list(y,z), .by = "i")
# # A tibble: 3 x 4
# i j k l
# <chr> <int> <int> <int>
# 1 a 1 NA 9
# 2 b 2 4 NA
# 3 c 3 5 7
Wir müssen nicht alle Spalten übernehmen, wir können ausgewählte Helfer von tidyselect verwenden und auswählen (da wir von .xallen .xSpalten ausgehen, werden diese beibehalten):
eat(x, list(y,z), starts_with("l") ,.by = "i")
# # A tibble: 3 x 3
# i j l
# <chr> <int> <int>
# 1 a 1 9
# 2 b 2 NA
# 3 c 3 7
oder entfernen Sie bestimmte:
eat(x, list(y,z), -starts_with("l") ,.by = "i")
# # A tibble: 3 x 3
# i j k
# <chr> <int> <int>
# 1 a 1 NA
# 2 b 2 4
# 3 c 3 5
Wenn die Liste benannt ist, werden die Namen als Präfixe verwendet:
eat(x, dplyr::lst(y,z), .by = "i")
# # A tibble: 3 x 4
# i j y_k z_l
# <chr> <int> <int> <int>
# 1 a 1 NA 9
# 2 b 2 4 NA
# 3 c 3 5 7
Wenn es Spaltenkonflikte gibt, .conflictkönnen Sie diese mit dem Argument lösen, indem Sie beispielsweise den ersten / zweiten nehmen, hinzufügen, zusammenführen oder verschachteln.
zuerst behalten:
eat(x, list(y, z, z2), .by = "i", .conflict = ~.x)
# # A tibble: 3 x 4
# i j k l
# <chr> <int> <int> <int>
# 1 a 1 NA 9
# 2 b 2 4 NA
# 3 c 3 5 7
zuletzt halten:
eat(x, list(y, z, z2), .by = "i", .conflict = ~.y)
# # A tibble: 3 x 4
# i j k l
# <chr> <int> <int> <dbl>
# 1 a 1 NA 100
# 2 b 2 4 100
# 3 c 3 5 100
hinzufügen:
eat(x, list(y, z, z2), .by = "i", .conflict = `+`)
# # A tibble: 3 x 4
# i j k l
# <chr> <int> <int> <dbl>
# 1 a 1 NA 109
# 2 b 2 4 NA
# 3 c 3 5 107
verschmelzen:
eat(x, list(y, z, z2), .by = "i", .conflict = dplyr::coalesce)
# # A tibble: 3 x 4
# i j k l
# <chr> <int> <int> <dbl>
# 1 a 1 NA 9
# 2 b 2 4 100
# 3 c 3 5 7
Nest:
eat(x, list(y, z, z2), .by = "i", .conflict = ~tibble(first=.x, second=.y))
# # A tibble: 3 x 4
# i j k l$first $second
# <chr> <int> <int> <int> <int>
# 1 a 1 NA 9 100
# 2 b 2 4 NA 100
# 3 c 3 5 7 100
NAWerte können durch das .fillArgument ersetzt werden.
eat(x, list(y, z), .by = "i", .fill = 0)
# # A tibble: 3 x 4
# i j k l
# <chr> <int> <dbl> <dbl>
# 1 a 1 0 9
# 2 b 2 4 0
# 3 c 3 5 7
Standardmäßig ist es erweitert, left_joinaber alle dplyr-Verknüpfungen werden durch das .modeArgument unterstützt, Fuzzy- Verknüpfungen werden auch durch das match_fun
Argument (es wird um das Paket gewickelt fuzzyjoin) oder durch Angabe einer Formel wie z. B. ~ X("var1") > Y("var2") & X("var3") < Y("var4")des
byArguments unterstützt.