【发布时间】:2017-08-18 13:17:50
【问题描述】:
数据
假设你有这个 data.table 或 dataframe(我正在使用 data.table):
a <- c(1, 6.7, 7.0, 6.5, 7.0, 7.2, 4.2, 5, 6.6,6.7)
b <- c(2,5.0, 3.5, 4.9, 7.8, 9.3, 8.0, 7.8, 8.0,10)
c <- c(3, 7.0, 5.5, 7.2, 7.7, 7.2, 8.0, 7.6, 7,6.7)
d <- c(4, 7.0, 7.0, 7.0, 6.9, 6.8, 9.0, 6.0, 6.6,6.7)
df <- data.frame(rbind(a,b,c,d))
X1 X2 X3 X4 X5 X6 X7 X8 X9 X10
a 1 6.7 7.0 6.5 7.0 7.2 4.2 5.0 6.6 6.7
b 2 5.0 3.5 4.9 7.8 9.3 8.0 7.8 8.0 10.0
c 3 7.0 5.5 7.2 7.7 7.2 8.0 7.6 7.0 6.7
d 4 7.0 7.0 7.0 6.9 6.8 9.0 6.0 6.6 6.7
问题
我试图将第一行的 X3 和 X4 相加,第二行的 X3 和 X4 和 X5 相加,等等......
我做了什么
我有一个叫做 iter 的向量:
iter <- c(1,2,3,4)
我所做的是一个for循环
for(i in 1:nrow(df)){
df$sum[i] <- sum(as.numeric(df[i,2:(2+iter[i])]),na.rm=T)}
你知道没有for循环的方法吗?
预期输出
output
13.7 #correspond to df[1,X3]+df[1,X4]
13.4 #correspond to df[2,X3]+df[2,X4]+df[2,X5]
27.4 #correspond to df[3,X3]+df[3,X4]+df[3,X5]+df[3,X6]
37.4 #correspond to df[4,X3]+df[4,X4]+df[4,X5]+df[4,X6]+df[4,X7]
编辑
iter <- c(1,2,3,4)
这里完全是任意的,所以我需要一个针对任何 iter 值的解决方案
【问题讨论】:
-
@lmo 现在试试我编辑了数据框和 for 循环
标签: r for-loop dataframe data.table