在数据帧的每一行上重复函数

Repeating function on each row of dataframe

我想应用一个函数,以便对于每个循环,该函数将从数据集的行中获取新的输入参数,并为每个循环提供单独的结果。

假设我有这样一个数据集:

df<-data.frame(A = 7:11, B = 1:5, C = 4:8, D = 10:14)

函数:

loop<-function(a,b,c,d){
sm <- sum(a,b,c,d)
return(sm)
}

我想自动化以下过程,以便该函数将为整个数据集分别计算每一行的总和:

loop (df[1,1],df[1,2],df[1,3],df[1,4])
loop (df[2,1],df[3,2],df[3,3],df[3,4])
loop (df[3,1],df[3,2],df[3,3],df[3,4])
loop (df[4,1],df[4,2],df[4,3],df[4,4])
loop (df[5,1],df[5,2],df[5,3],df[5,4])

我尝试使用 apply 功能,但是,我无法正确使用。有人可以告诉我一个解决方案吗?谢谢你。

使用rowSums

rowSums(df)
#[1] 22 26 30 34 38

如果您仍想使用 loop 功能,请试试这个

mapply(loop,df[,1],df[,2],df[,3],df[,4])
#[1] 22 26 30 34 38