我想打電話給計算像下面一組彙總統計的data.table裏面的函數:如何調用返回data.table中的多行和多列的函數?
summ.stats <- function(vec) {
list(
Min = min(vec),
Mean = mean(vec),
S.D. = sd(vec),
Median = median(vec),
Max = max(vec))
}
,我想它調用的j
一個data.table
:
DT <- data.table(a=c(1,2,3,1,2,3),b=c(1,4,3,2,1,4),c=c(2,3,4,5,2,1))
DT[, summ.stats(b), by=a]
這很好,我也得到:
a Min Mean S.D. Median Max
1: 1 1 1.5 0.7071068 1.5 2
2: 2 1 2.5 2.1213203 2.5 4
3: 3 3 3.5 0.7071068 3.5 4
但我感興趣的傳遞多個變量summ.stats。例如:
DT[, summ.stats(b, c), by=a]
我想要得到的東西,如:
a Var Min Mean S.D. Median Max
1: 1 b 1 1.5 0.7071068 1.5 2
2: 2 b 1 2.5 2.1213203 2.5 4
3: 3 b 3 3.5 0.7071068 3.5 4
4: 1 c 2 3.5 2.1213203 3.5 5
5: 2 c 2 2.5 0.7071068 2.5 3
6: 3 c 1 2.5 2.1213203 2.5 4
什麼是做到這一點的最好方法是什麼?
這是一個更簡單的解決方案,更符合我的期望。但我想我們可以刪除'as.list'函數,不是嗎? – Rodrigo
@RogerBill,是的,你是對的。先將'sapply'或'lapply'內部轉換爲'list'。 – Arun