我有以下列表:
df = read.table(text = 'Var1 Freq
1 12
2 19
3 3
5 7
6 55
9 17', header = TRUE)
df1 = read.table(text = 'Var1 Freq
1 16
2 1
3 22
5 87
6 5
7 9
11 76', header = TRUE)
df2 = read.table(text = 'Var1 Freq
1 17
2 11
5 7
6 32
7 10
15 6
20 54', header = TRUE)
lst = list(df, df1, df2)
我需要将每个Freq
col与每个data.frame的相对Var1
行相加。
这是我想要的输出:
Var1 Freq
1 45
2 31
3 25
5 101
6 92
7 19
9 17
11 76
15 6
20 54
我该怎么做? Map
在这种情况下有帮助吗?
由于
答案 0 :(得分:3)
将do.call
rbind
列表的各个数据框用于单个data.frame,然后使用aggregate
到sum
with(do.call(rbind, lst), aggregate(Freq, by = list(Var1), sum))
# Group.1 x
#1 1 45
#2 2 31
#3 3 25
#4 5 101
#5 6 92
#6 7 19
#7 9 17
#8 11 76
#9 15 6
#10 20 54
答案 1 :(得分:2)
另一个想法是来自rbindlist
data.table
library(data.table)
rbindlist(lst)[, .(Freq = sum(Freq)), Var1]
# Var1 Freq
# 1: 1 45
# 2: 2 31
# 3: 3 25
# 4: 5 101
# 5: 6 92
# 6: 9 17
# 7: 7 19
# 8: 11 76
# 9: 15 6
#10: 20 54