さまざまな個人で構成されるデータセットがあり、各個人には一意の ID があります。各個人はデータセットに複数回出現する可能性がありますが、1 つまたは 2 つの変数 (個人ごとに約 80 あります) が異なることに加えて、値はデータセット内の同じユーザー ID の各エントリで同じである必要があることを理解しています。
可能であれば、データを折りたたんでみたいと思います。私の主な障害は、バックポピュレートする必要がある特定の null 値です。次のような重複排除を実現できる関数を探しています。
# Build sample dataset
df1 = data.frame(id=rep(1:6,2)
,classA=rep(c('a','b'),6)
,classB=rep(c(1001:1006),2)
)
df1= df1[order(df1$id),]
df1$classC=c('a',NA,'b',NA,NA,NA,'e','d', NA, 'f', NA, NA)
df1[10,"classB"]=NA
df1=df1[df1$id!=6,]
#sample dataset
> df1
id classA classB classC
1 1 a 1001 a
7 1 a 1001 <NA>
2 2 b 1002 b
8 2 b 1002 <NA>
3 3 a 1003 <NA>
9 3 a 1003 <NA>
4 4 b 1004 e
10 4 b 1004 d
5 5 a 1005 <NA>
11 5 a NA f
# what I'm looking for
> deduplicate(df1, on='id')
id classA classB classC
1 1 a 1001 a
2 2 b 1002 b
3 3 a 1003 <NA>
4 4 b 1004 d
5 4 b 1004 e
6 5 a 1005 f