您可以使用setNames
,如下所示:
blubb <- setNames(aggregate(dat$two ~ dat$one, ...), c("One", "Two"))
或者,您可以绕过slick formula方法,使用以下语法:
blubb <- aggregate(list(One = dat$one), list(Two = dat$two), ...)
使现代化
此更新只是为了帮助您开始自己推导解决方案.
如果你判断代码stats:::aggregate.formula
,你会看到下面几行接近尾声:
if (is.matrix(mf[[1L]])) {
lhs <- as.data.frame(mf[[1L]])
names(lhs) <- as.character(m[[2L]][[2L]])[-1L]
aggregate.data.frame(lhs, mf[-1L], FUN = FUN, ...)
}
else aggregate.data.frame(mf[1L], mf[-1L], FUN = FUN, ...)
如果您只想将函数名附加到聚合的变量,那么您可以将其更改为:
if (is.matrix(mf[[1L]])) {
lhs <- as.data.frame(mf[[1L]])
names(lhs) <- as.character(m[[2L]][[2L]])[-1L]
myOut <- aggregate.data.frame(lhs, mf[-1L], FUN = FUN, ...)
colnames(myOut) <- c(names(mf[-1L]),
paste(names(lhs), deparse(substitute(FUN)), sep = "."))
}
else {
myOut <- aggregate.data.frame(mf[1L], mf[-1L], FUN = FUN, ...)
colnames(myOut) <- c(names(mf[-1L]),
paste(strsplit(gsub("cbind\\(|\\)|\\s", "",
names(mf[1L])), ",")[[1]],
deparse(substitute(FUN)), sep = "."))
}
myOut
这基本上捕获了使用deparse(substitute(FUN))
为FUN
输入的值,因此您可能可以修改函数以接受自定义后缀,或者甚至是后缀向量.通过一些工作,这可能会有所改进,但我不打算这么做!
下面是a Gist个应用了这个概念,创建了一个名为"myAgg"的函数.
以下是一些示例输出of just the resulting column names:
> names(myAgg(weight ~ feed, data = chickwts, mean))
[1] "feed" "weight.mean"
> names(myAgg(breaks ~ wool + tension, data = warpbreaks, sum))
[1] "wool" "tension" "breaks.sum"
> names(myAgg(weight ~ feed, data = chickwts, FUN = function(x) mean(x^2)))
[1] "feed" "weight.function(x) mean(x^2)"
请注意,只有聚合的变量名会更改.但也要注意,如果使用自定义函数,最终会得到一个非常奇怪的列名!