5

我在 R 中工作,我想遍历列表的行并按名称引用列值,如下所示:

for(row in Data) {
    name <- row$name
    age <- row$age
    #do something cool here
}

我的数据如下所示:

name, age, gender, weight
Bill, 23, m, 134
Carl, 40, m, 178

我知道这应该是微不足道的,但我找不到帮助。提前谢谢。

所以这是我正在使用的原始数据。前面的表格就是一个例子:

structure(list(startingTemp = c(100L, 100L, 100L, 100L, 100L), 
    endingTemp = c(1L, 1L, 1L, 1L, 1L), movesPerStep = c(200000L, 
    100000L, 20000L, 10000L, 2000L), coolingCoefficient = c(0.99, 
    0.99, 0.99, 0.99, 0.99), numberTempSteps = c(459L, 459L, 
    459L, 459L, 459L), costPerRun = c(91800000L, 45900000L, 9180000L, 
    4590000L, 918000L)), .Names = c("startingTemp", "endingTemp", 
"movesPerStep", "coolingCoefficient", "numberTempSteps", "costPerRun"
), row.names = c(NA, 5L), class = "data.frame")
4

1 回答 1

12

您可以使用以下方法执行此操作apply

apply(Data, 1, function(row) {
    name <- row["name"]
    age <- row["age"]
    #do something cool here
})

这通常用于返回一个新的向量、矩阵或列表,这取决于函数返回的内容。例如,假设您要将函数numberTempSteps / costPerRun应用于每一行。你会这样做:

apply(Data, 1, function(row) row["numberTempSteps"] / row["costPerRun"])

(请注意,对于此示例,您也可以这样做Data$numberTempSteps / Data$costPerRun)。

于 2012-09-06T06:29:36.887 回答