在过去的两天里,我在论坛和网络上进行了高低搜索,并分解了我的脚本以尝试找到问题,但由于某种原因,我无法在第一行之后正常工作:
numbers <- mtcars[1:6,]
nnn <- c(1:(nrow(numbers)))
for (i in nnn){
ly <- numbers[i,]
numbers[i,12]<- sum(abs(ly) < 5e0)
}
这将返回:
> numbers
mpg cyl disp hp drat wt qsec vs am gear carb V12
Mazda RX4 21.0 6 160 110 3.90 2.620 16.46 0 1 4 4 6
Mazda RX4 Wag 21.0 6 160 110 3.90 2.875 17.02 0 1 4 4 NA
Datsun 710 22.8 4 108 93 3.85 2.320 18.61 1 1 4 1 NA
Hornet 4 Drive 21.4 6 258 110 3.08 3.215 19.44 1 0 3 1 NA
Hornet Sportabout 18.7 8 360 175 3.15 3.440 17.02 0 0 3 2 NA
Valiant 18.1 6 225 105 2.76 3.460 20.22 1 0 3 1 NA
如您所见,当 i 为 1 时,ly 是马自达 rx4 行,它执行
sum(abs(ly) < 5e0)
正确地,将值 6 放在新的第 12 列中。然而,除此之外,即使我已经确定它正确地循环遍历 i,并且为 i 的每次迭代正确返回 ly,它也不会计算行 2:5 的总和部分
对于大多数人来说,我在这里做错了什么可能真的很明显,但对于我的生活,我无法选择。我是 R 和编程的新手,几乎是自学的,在过去的几周里,我已经写了很多成功的循环和脚本,但这让我目瞪口呆。我们研究组中使用 Matlab 的其他人和我一起解决了这个问题,问题和我一样,她也想不出为什么它不起作用。
到目前为止,我使用 mtcars 只是为了测试循环,以便论坛上的人可以轻松访问它。一旦我知道它有效,我就会为我的数据集(相当大)翻译它。
最佳答案
在 R 中通常不需要使用 for 循环。更像 R 的解决方案是使用 apply
:
apply(numbers, 1, function(x) sum(abs(x) < 5e0))
Mazda RX4 Mazda RX4 Wag Datsun 710 Hornet 4 Drive
6 6 7 6
Hornet Sportabout Valiant
6 6
将其添加为列仅涉及:
numbers$V12 = apply(numbers, 1, function(x) sum(abs(x) < 5e0))
关于您的代码的一些说明:
1:(nrow(numbers))
包裹 c
。 seq_len
可以更轻松地生成索引向量,即 seq_len(nrow(numbers))
。 关于r - 按数据框行计算小于 x 的值数,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/16475705/