我有一个如下所示的数据框:
a <- c("jan", "mar", "jan", "feb", "feb")
b <- c("feb", "mar", "mar", "jan", "mar")
c <- c("jan", "feb", "feb", "jan", "jan")
d <- c("jan", "mar", "jan", "feb", "feb")
e <- c("feb", "jan", "feb", "mar", "mar")
f <- c("jan", "feb", "feb", "jan", "jan")
xxx <- data.frame(a,b,c,d,e,f)
xxx
我需要在字符串的每个实例的xxx中找到位置,比如&#34; jan&#34;。我可以看到在df中每个插槽中运行的hacky解决方案,并检查它是否= =&#34; jan&#34;,但确实是一种正确而简单的方法。理想情况下,我希望将结果作为坐标列表返回。
感谢您的帮助!
答案 0 :(得分:8)
函数which
有一个名为arr.ind
的参数,它将为您提供一个2列矩阵,指示每个匹配的位置
which(xxx == "jan", arr.ind=TRUE)
row col
[1,] 1 1
[2,] 3 1
[3,] 4 2
[4,] 1 3
[5,] 4 3
[6,] 5 3
[7,] 1 4
[8,] 3 4
[9,] 2 5
[10,] 1 6
[11,] 4 6
[12,] 5 6
答案 1 :(得分:2)
首先,要测试的字符串集可以通过以下方式获得:
mnths <- unique(c(t(xxx)))
然后,例如对于第一个元素“jan”,实例的位置可以通过以下方式给出:
which(xxx == mnths[1], arr.ind = TRUE)