我正在尝试以一种非常具体的方式为我的研究组织一个数据集,但是我是 R 的新手,我真的很挣扎,任何帮助都将不胜感激。
我试图在每第三列(从第一列开始)获取单元格的值并将其乘以它旁边的列,但前提是所述单元格中有负值。在此之后,我想将结果汇总在一起并将其存储在外部电子表格的新列中。
到目前为止,我编写的代码如下:
NegTotal = NULL
p = NULL
for (i in 1:nrow(Datafile))
{for (j in 1:ncol(Datafile))
{if ((j %% 3 == 0) && (Datafile [i,j] < 0)) {
p <- (datafile[i,j] * datafile[i,j+1])
NegTotal <- sum(p) }
else { }
}
}
for (l in seq(along = NegTotal)) {
dim(newColumn)
AsNewData.DataColumn("datafile", GetType(System.String))
NewColumn.DefaultValue = "NegTotal"
table.Columns.Add(newColumn)
}
我知道这段代码可能是完全错误的,这是我第一次使用 R,而且我一般不太精通计算机编程。
当前数据排列如下:
df <- data.frame(F1 = c( 1, -2, -1), E1 = c(1, 1, 0), Y1 = c(0, 0, 1),
F2 = c(-1, 2, -1), E2 = c(1, 1, 1), Y2 = c(0, 0, 1),
F3 = c(-2, -2, -1), E3 = c(1, 1, 1), Y3 = c(1, 1, 0))
# F1 E1 Y1 F2 E2 Y2 F3 E3 Y3
# 1 1 1 0 -1 1 0 -2 1 1
# 2 -2 1 0 2 1 0 -2 1 1
# 3 -1 0 1 -1 1 1 -1 1 0
期望的输出:
# F1 E1 Y1 F2 E2 Y2 F3 E3 Y3 NegTotal
# 1 1 1 0 -1 1 0 -2 1 1 -3
# 2 -2 1 0 2 1 0 -2 1 1 -4
# 3 -1 0 1 -1 1 1 -1 1 0 -2
所以如果 x = Fy * Ey; NegTotal = x1 + x2 + x3,仅当 F$y < 0 时。
我希望一切都有意义!