根据Group By折叠R中的稀疏数据帧

时间:2018-03-02 18:19:09

标签: r dplyr sparse-matrix plyr summarize

我的df看起来像这样:

Name Var0 Var1 Var2 Var3 Var4
A 0.1 NA NA NA NA
A NA 0.3 NA NA NA
A NA NA 0.4 NA NA
A NA NA NA 0.7 NA
A NA NA NA NA 0.9
B 0.2 NA NA NA NA
B NA 0.5 NA NA NA
B NA NA 0.8 NA NA
B NA NA NA 0.1 NA
B NA NA NA NA 0.3

它本质上是一个稀疏矩阵,按第一列“名称”分组。如何折叠行,以便每个名称只有一行?我尝试了多种解决方案,包括groupby和summaryrize函数,但找不到折叠矩阵的好方法。

我想要的输出:

 Name Var0 Var1 Var2 Var3 Var4
 A 0.1 0.3 0.4 0.7 0.9
 B 0.2 0.5 0.8 0.1 0.3

1 个答案:

答案 0 :(得分:3)

这应该这样做

df %>% group_by(Name) %>% summarise_all(funs(na.omit(.)[1]))