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

问题描述 投票:0回答:1

这个问题在这里已有答案:

我有一个看起来像这样的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和summarize函数,但找不到折叠矩阵的好方法。

我想要的输出:

 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
r dplyr sparse-matrix plyr summarize
1个回答
3
投票

这应该做到这一点

df %>% group_by(Name) %>% summarise_all(funs(na.omit(.)[1]))
© www.soinside.com 2019 - 2024. All rights reserved.