aggregate()
'u, daha fazla işlevle, toplamaların bir matrisin parçası olarak değil, ayrı sütunlar olarak depolanacağı şekilde kullanabilir miyim? Group.1, cyl.1, cyl.2
sütunlarıyla, Group.1, cyl
numaralı veri çerçevesine sahip olmak istiyorum.Diğer işlevlerle Agrega() -
# Only one function
> aggdata <-aggregate(mtcars["cyl"], by=list(vs), FUN=mean, na.rm=TRUE)
> aggdata
Group.1 cyl
1 0 7.444444
2 1 4.571429
> str(aggdata)
'data.frame': 2 obs. of 2 variables:
$ Group.1: num 0 1
$ cyl : num 7.44 4.57
>
# Two functions
> aggdata <-aggregate(mtcars["cyl"], by=list(cyl), FUN=function(x) c(length(x),mean(x)))
> aggdata
Group.1 cyl.1 cyl.2
1 4 11 4
2 6 7 6
3 8 14 8
> str(aggdata)
'data.frame': 3 obs. of 2 variables:
$ Group.1: num 4 6 8
$ cyl : num [1:3, 1:2] 11 7 14 4 6 8
> aggdata$cyl
[,1] [,2]
[1,] 11 4
[2,] 7 6
[3,] 14 8
+1. Bu seçeneği paylaşmayı düşündüm, çünkü sözdizimini çok daha iyi seviyorum, ama daha önce karşılaştığım ve toparlamak için biraz garip gelmekle 'toplamanın' çıktısı ile ne yapacağına dair asıl soruya değinmiyor. . – A5C1D2H2I1M1N2O1R2T1
@AnandaMahto Bu soruya cevap vermediğine katılıyorum (ve soru sizinki sizin cevabınızdır), fakat temel olarak OP'nin yanlış soruyu sorduğunu düşünüyorum :) – eddi
Sadece buldum [kaynak cevap] (http://stackoverflow.com/a/14759569/1270695). Buna benzer birkaç soru daha var, ama bu, "do.call (data.frame, ...)" yaklaşımını öğrendiğim yerdi. – A5C1D2H2I1M1N2O1R2T1