我有一个 18x18 的数据框,我想将所有可能的列对相互比较,以便对于每对两列,将 18 行中的值相互比较。
由于我的数据太大而无法放在这里,所以我写了一个小例子来说明我到目前为止的想法:
> a <- c(1:18)
> b <- c(18:1)
> c <- c(1:9,18:10)
data <- as.data.frame(matrix(c(a,b,c), ncol = 3, nrow = 18))
> data
V1 V2 V3
1 1 18 1
2 2 17 2
3 3 16 3
4 4 15 4
5 5 14 5
6 6 13 6
7 7 12 7
8 8 11 8
9 9 10 9
10 10 9 18
11 11 8 17
12 12 7 16
13 13 6 15
14 14 5 14
15 15 4 13
16 16 3 12
17 17 2 11
18 18 1 10
说,我想将 col V1 与 V3 进行比较,并且当第一个 col (V1) 的值大于时,将两列(V1 和 V3)中的相等值分配为 1,并且当第二个 col (V3) 更大,分配一个 2。我可以使用以下代码为每一对手动执行此操作,将结果转换为新的数据帧 freqcomp:
> freqcomp <- as.data.frame(table(ifelse(data[,1]==data[,3],0,ifelse(data[,1]>data[,3],1,ifelse(data[,1]<data[,3],2,NA)))))
>
> freqcomp
Var1 Freq
1 0 10
2 1 4
3 2 4
我怎样才能为我拥有的所有列自动进行这种比较?是否有一个很好的 for 循环来运行所有列或我可以使用的任何其他函数?