说我有一些矩阵,例如:
> m = matrix(rep(c(0, 0, 1), 4), nrow = 4)
> m
[,1] [,2] [,3]
[1,] 0 0 1
[2,] 0 1 0
[3,] 1 0 0
[4,] 0 0 1
如果我运行which
,我会得到正常索引列表:
> which(m == 1)
[1] 3 6 9 12
我希望获得类似矩阵索引的内容 - 每个索引都包含行号和列号:
[,1] [,2]
[1,] 3 1
[2,] 2 2
[3,] 1 3
[4,] 4 3
有没有简单的功能呢?此外,它应该以某种方式包含行名和列名:
> rownames(m) = letters[1:4]
> colnames(m) = letters[5:7]
> m
e f g
a 0 0 1
b 0 1 0
c 1 0 0
d 0 0 1
但我现在不怎么样,也许就像
[,1] [,2] [,3] [,4]
[1,] 3 1 c e
[2,] 2 2 b f
[3,] 1 3 a g
[4,] 4 3 d g
或者,可能返回2个向量(用于行和列),例如
c b a d
3 2 1 4
e f g g
1 2 3 3
答案 0 :(得分:47)
对于第一个问题,您还需要将arr.ind= TRUE
传递给which
:
> which(m == 1, arr.ind = TRUE)
row col
[1,] 3 1
[2,] 2 2
[3,] 1 3
[4,] 4 3
答案 1 :(得分:5)
您不能在矩阵中混合数字和alpha,但您可以在data.frame中使用
> indices <- data.frame(ind= which(m == 1, arr.ind=TRUE))
> indices$rnm <- rownames(m)[indices$ind.row]
> indices$cnm <- colnames(m)[indices$ind.col]
> indices
ind.row ind.col rnm cnm
c 3 1 c e
b 2 2 b f
a 1 3 a g
d 4 3 d g