我有两个相同大小的不同矩阵,一个有 NA 值,一个没有,例如:
mat=matrix(rnorm(9, mean=20, sd=10), nrow=3)
mat2=matrix(rnorm(9, mean=20, sd=10), nrow=3)
mat2[mat2<20]=NA
mat
[,1] [,2] [,3]
[1,] 21.67730 17.978427 17.24766
[2,] 14.71108 16.970846 30.29543
[3,] 28.65521 9.191494 18.83665
mat2
[,1] [,2] [,3]
[1,] 28.6093 NA 32.26887
[2,] NA NA NA
[3,] NA 20.19428 30.25038
Run Code Online (Sandbox Code Playgroud)
我可以使用以下方法识别 NA 值的坐标(行/列)mat2:
which(is.na(mat2), TRUE)
Run Code Online (Sandbox Code Playgroud)
然后我如何使用这些坐标来替换 中的相同mat值NA?生产:
mat
[,1] [,2] [,3]
[1,] 21.67730 NA 17.24766
[2,] NA NA NA
[3,] NA 9.191494 18.83665
Run Code Online (Sandbox Code Playgroud)
这是最好的方法吗?提前致谢。
矩阵在内部表示为向量(带有有关维度的信息),因此您可以执行类似的操作
mat[is.na(mat2)] <- NA
Run Code Online (Sandbox Code Playgroud)
这将创建一个布尔向量,指示 mat2 的哪些元素NA,然后将 NA 分配给 mat 的这些元素。