0

问题:
使用 R,我有两个数组,都具有相同类型的数据(例如,相同的行、列和/或层名称)。但是,它们具有不同的维度。行和列名称部分重叠。也就是说,大多数级别的行和列因子都出现在两个数组中,但有些是每个数组独有的。我想取其中一个数组,并将其削减,以便仅包含两个数组共有的行和列级别。我以前可以通过编写自己的非常复杂的函数来完成此操作,但看起来这确实应该是一个简单的操作。有人可以为此指出正确的方向吗?

这是一些示例代码,我认为这是完成此任务的一种不必要的费力方法。在这种情况下, sp.ixn.core 是一个较小的 2D 数组,我想减少一个 3D 数组,以便行和列与 sp.ixn.core 匹配……最后一点是我仔细检查数字是否加起来正确。

temp=table(data$plant,data$Species,data$jdate)
temp2=array(,dim=c(nrow(sp.ixn.core),ncol(temp),dim(temp)[3]))

for (i in 1:length(rownames(sp.ixn.core))){
temp2[i,,] = temp[rownames(temp) == rownames(sp.ixn.core)[i],,]
}

colnames(temp2) = colnames(temp)
temp3=array(,dim=c(nrow(sp.ixn.core),ncol(sp.ixn.core),dim(temp)[3]))
for (i in 1:length(colnames(sp.ixn.core))){
temp3[,i,] = temp2[,colnames(temp2) == colnames(sp.ixn.core)[i],]
}
dim(temp3)

sp.ixn.core.tbl = temp3
dimnames(sp.ixn.core.tbl)[[3]] = dimnames(temp)[[3]]
dimnames(sp.ixn.core.tbl)[[2]] = colnames(sp.ixn.core)
dimnames(sp.ixn.core.tbl)[[1]] = rownames(sp.ixn.core)
dimnames(sp.ixn.core.tbl)

for (i in 1:nrow(sp.ixn.core)){
    if (sum(sp.ixn.core.tbl[i,,]) == rowSums(sp.ixn.core)[i])
        print("yes")
}

for (i in 1:ncol(sp.ixn.core)){
    if (sum(sp.ixn.core.tbl[,i,]) == colSums(sp.ixn.core)[i])
        print("yes")
}
4

1 回答 1

0

我想你可能只需要:

newtemp <- temp[ rownames(temp) %in% rownames(sp.ixn.core),
                 colnames(temp) %in% colnames(sp.ixn.core),
                 dimnames(temp)[3] %in% dimnames(sp.ixn.core)[3] ]

自从 dimnames(x)[1] == rownames(x) 起,您就可以使用 'dimnames'。正如 nograpes 建议的那样,最好针对您的实际数据对象进行测试。我有点担心你的表调用可能会返回一个带有 NULL 暗名的对象。

于 2012-10-04T20:51:27.850 回答