聚合而不减少数据帧的维度

时间:2016-06-16 06:05:31

标签: r group-by aggregate dimension

我正在尝试使用R中的聚合函数,我希望输出数据框的维度保持不变。例如:假设我有以下数据框

Name------Type------    Price   
Prod1-----A--------       $1
Prod2----A---------       $5
Prod3----B----------       $7
Prod4-----B---------       $9

在R中使用聚合函数后,通过聚合Type和函数作为价格的总和。我得到以下结果:

Type-------Value
A-----------6
B-----------16 

但是,我希望数据框的维度保持不变。例如:

Name-----Type----Price----Value  
Prod1----A-------$1-------$6
Prod2----A-------$5--------$6
Prod3----B--------$7-------$16
Prod 4----B-------$9--------$16

我不想在这个应用程序中使用Loop。请建议任何其他方式。

2 个答案:

答案 0 :(得分:5)

我们可以使用ave

中的base R
df1$Value <- with(df1, paste0("$", ave(as.numeric(sub("[$]", "", Price)), 
                          Type, FUN = sum)))
df1$Value
#[1] "$6"  "$6"  "$16" "$16"

答案 1 :(得分:2)

使用dplyr

library(dplyr)
df %>% 
  group_by(Type) %>% 
  mutate(Value = sum(Price))

或使用data.table

library(data.table)
setDT(df)[, Value := sum(Price), by = Type]

#    Name Type Price Value
#1:   P1    A     1     6
#2:   P1    A     5     6
#3:   P3    B     7    16
#4:   P4    B     9    16