3

3 つの異なるファイルから 3 つの異なるデータフレームにデータを読み込みました。マージ機能を試しましたが、目的の出力が得られないようです。私のデータフレームは次のとおりです。

df1:

someName    someMOD someID
A   T754(P),M691(O),S692(P),S694(P),S739(P),S740(P),S759(P),S762(P) 1
B   S495(P) 2
C   S162(P),Q159(D) 3
D   S45(P),C47(C),S48(P),S26(P) 4
E   S18(P)  5

df2:

someName    someMOD someID
C   S162(P),Q159(D) 3
D   S45(P),C47(C),S48(P),S26(P) 4
F   S182(P) 6
E   S18(P)  5
Z   Q100(P) 9
A   T754(P),M691(O),S694(P),S739(P),S740(P) 1

df3:

someName    someMOD someID
A   T754(P),M691(O),S692(P),S694(P),S739(P),S740(P),S759(P) 1
B   S495(P) 2
D   S45(P),C47(C),S48(P),S26(P) 4
E   S18(P)  5
F   S182(P) 6
L   Z182(P) 8
C   S162(P),Q159(D) 3

someID 列によってマージされた次のような出力が必要です。 ここに画像の説明を入力

どんな助けでも本当に感謝しています.Thanks.

4

3 に答える 3

3

Reduce複数のデータ フレームを結合するために使用します。面倒なことの 1 つReduceは、基になる関数に正確に 2 つの引数を渡すことです。そのため、これを回避する必要があります。

mymerge <- function(x, y)
merge(x, y, by=c("someName", "someID"), all=TRUE))

Reduce(mymerge, list(df1, df2, df3))
于 2013-06-22T05:46:16.863 に答える
2

library(data.table)

dt1 <- data.table(df1, key="someName,someID")
dt2 <- data.table(df2, key="someName,someID")
dt3 <- data.table(df3, key="someName,someID")

DT <- dt1[dt2[dt3]]
于 2013-06-22T11:24:37.607 に答える