首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用lapply()-function求R中数据帧中每一行的均值

使用lapply()-function求R中数据帧中每一行的均值
EN

Stack Overflow用户
提问于 2018-06-23 11:10:44
回答 2查看 4.8K关注 0票数 1

我有一个数据框架,包括对7个变量的36次观察(技术、部门,2010年、2011年、2012年、2013年、2014年)。变量1和2为“因子”类型,变量3、4、5、6和7为数值型,有一些NAs。

我希望使用lapply()-function来查找每行的平均值(变量3、4、5、6和7的平均值),然后用这些方法创建一个新列(cbind)。

可以这样做吗,比如使用一个矩阵和apply()-function,您可以在其中指定行与列的选择:

代码语言:javascript
复制
apply(matrix, 1, mean) #will go through all the rows and calculate the mean for each one.
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-06-23 11:30:17

由于OP提到使用任何一个lapply/apply/sapply or tapply,因此使用apply的解决方案可以如下所示:

代码语言:javascript
复制
df$meanVal <- apply(df[3:7], 1, mean, na.rm = TRUE)

新列meanVal将包含列3:7mean

票数 2
EN

Stack Overflow用户

发布于 2018-06-23 12:31:18

rowMeans函数的效率将大大提高:

代码语言:javascript
复制
df$meanVal <- rowMeans(df[3:7], na.rm = TRUE)

在行上使用lapply并不是必要的,因为apply(dafa,1,fun)通常可以正常工作。但在某些情况下,你可能想:

代码语言:javascript
复制
lapply(split(data,seq(nrow(data))),fun)

或:

代码语言:javascript
复制
by(data,seq(nrow(data)),fun)
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51000602

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档