2 つの類似したデータ フレームをマージして、重要度の高いデータ フレームを作成するにはどうすればよいですか?
例えば:
データフレーム 1
Date Col1 Col2
jan 2 1
feb 4 2
march 6 3
april 8 NA
データフレーム 2
Date Col2 Col3
jan 9 10
feb 8 20
march 7 30
april 6 40
これらを日付別にマージし、データフレーム 1 を優先しますが、データフレーム 2 は空白を埋めます
データフレームマージ
Date Col1 Col2 Col3
jan 2 1 10
feb 4 2 20
march 6 3 30
april 8 6 40
編集 - 解決策
commonNames <- names(df1)[which(colnames(df1) %in% colnames(df2))]
commonNames <- commonNames[commonNames != "key"]
dfmerge<- merge(df1,df2,by="key",all=T)
for(i in commonNames){
left <- paste(i, ".x", sep="")
right <- paste(i, ".y", sep="")
dfmerge[is.na(dfmerge[left]),left] <- dfmerge[is.na(dfmerge[left]),right]
dfmerge[right]<- NULL
colnames(dfmerge)[colnames(dfmerge) == left] <- i
}