我有一个包含61个矩阵的矩阵列表。下面是61个矩阵之一的示例。
list_matrix_Tanzania_Mod500
[[60]]
LU_2000
[1,] 12
[2,] 12
[3,] 12
[4,] 12
[5,] 12
[6,] 12
[7,] 12
[8,] 12
[9,] 12
[10,] 11
[11,] 11
[12,] 12
[13,] 11
[14,] 12
[15,] 12
我想在矩阵列表的每个矩阵中添加10个新列。添加这些新列后,我想为每个列添加一个标题名称,其值为NA
:"ID", "LU_1990", "CHLU_90_00", "LU_2005", "CHLU_00_05", "Tile", "UNIQ_ID", "AREA", "Sour_90_00", "Sour_00_05"
我现在想用几个矩阵填充矩阵列表list_matrix_Tanzania_Modis:LU_Mod2000, LU_Mod2005 and list_matrix_Tanzania
。我尝试了这个但是列没有很好地更新。在Fot实例中,当我运行LU_Mod2005的Map
代码行时,LU_2000的值将从矩阵中删除。
columnsToTransfer1 <- 'LU_2000'
columnsToTransfer2 <- 'LU_2005'
columnsToTransfer3<- ('ID', 'Tile', 'UNIQ_ID')
Map(function(x,y,z) {x[,z] <- y[,z];x},
list_matrix_Tanzania_Modis, LU_Mod2000, columnsToTransfer1)
Map(function(x,y,z) {x[,z] <- y[,z];x},
list_matrix_Tanzania_Modis, LU_Mod2005, columnsToTransfer2)
Map(function(x,y,z) {x[,z] <- y[,z];x},
list_matrix_Tanzania_Modis, list_matrix_Tanzania, columnsToTransfer3)
这个技巧有效,但我想保留矩阵列表的名称为list_matrix_Tanzania_Modis
list_matrix_Tanzania_Modis1<- Map(function(x,y,z) {x[,z] <- y[,z];x},
list_matrix_Tanzania_Modis, LU_Mod2000, columnsToTransfer1)
list_matrix_Tanzania_Modis2<-Map(function(x,y,z) {x[,z] <- y[,z];x},
list_matrix_Tanzania_Modis1, LU_Mod2005, columnsToTransfer2)
答案 0 :(得分:1)
如果我理解正确,在创建正确尺寸的空矩阵后,应该使用简单的cbind
:
示例输入:
L <- list(matrix(1:3, ncol = 1, dimnames = list(NULL, "a")),
matrix(1:5, ncol = 1, dimnames = list(NULL, "b")))
L
# [[1]]
# a
# [1,] 1
# [2,] 2
# [3,] 3
#
# [[2]]
# b
# [1,] 1
# [2,] 2
# [3,] 3
# [4,] 4
# [5,] 5
您要添加的新列:
newcols <- c("ID", "LU_1990", "CHLU_90_00", "LU_2005", "CHLU_00_05",
"Tile", "UNIQ_ID", "AREA", "Sour_90_00", "Sour_00_05")
使用lapply
循环浏览列表,将相关的空列添加到每个列表项。
myNewList <- lapply(L, function(x) {
M <- matrix(NA, nrow = nrow(x), ncol = 10, dimnames = list(NULL, newcols))
cbind(x, M)
})
myNewList
# [[1]]
# a ID LU_1990 CHLU_90_00 LU_2005 CHLU_00_05 Tile UNIQ_ID AREA Sour_90_00 Sour_00_05
# [1,] 1 NA NA NA NA NA NA NA NA NA NA
# [2,] 2 NA NA NA NA NA NA NA NA NA NA
# [3,] 3 NA NA NA NA NA NA NA NA NA NA
#
# [[2]]
# b ID LU_1990 CHLU_90_00 LU_2005 CHLU_00_05 Tile UNIQ_ID AREA Sour_90_00 Sour_00_05
# [1,] 1 NA NA NA NA NA NA NA NA NA NA
# [2,] 2 NA NA NA NA NA NA NA NA NA NA
# [3,] 3 NA NA NA NA NA NA NA NA NA NA
# [4,] 4 NA NA NA NA NA NA NA NA NA NA
# [5,] 5 NA NA NA NA NA NA NA NA NA NA