将id列添加到列表元素的一致方法

Consistent method to add id column to list elements

我在使用 mapply 将 ID 列添加到列表时遇到问题(在更大的函数中)。

对于大多数列表,下面的代码工作正常...

m1 <- matrix(data = 1:32, nrow = 8, ncol = 4)
m2 <- matrix(data = 1:8, nrow = 2, ncol = 4)
m3 <- matrix(data = 1:16, nrow = 4, ncol = 4)
m4 <- matrix(data = 1:4, nrow = 1, ncol = 4)
colnames(m1) <- colnames(m2) <- colnames(m3) <- colnames(m4) <- LETTERS[1:4]

a <- list(m1, m2, m3, m4)
mapply(cbind, a, m = 1:4)
# [[1]]
#      A  B  C  D m
# [1,] 1  9 17 25 1
# [2,] 2 10 18 26 1
# [3,] 3 11 19 27 1
# [4,] 4 12 20 28 1
# [5,] 5 13 21 29 1
# [6,] 6 14 22 30 1
# [7,] 7 15 23 31 1
# [8,] 8 16 24 32 1
# 
# [[2]]
#      A B C D m
# [1,] 1 3 5 7 2
# [2,] 2 4 6 8 2
# 
# [[3]]
#      A B  C  D m
# [1,] 1 5  9 13 3
# [2,] 2 6 10 14 3
# [3,] 3 7 11 15 3
# [4,] 4 8 12 16 3
# 
# [[4]]
#      A B C D m
# [1,] 1 2 3 4 4

但是当我有包含相同维度矩阵的列表时,不再返回列表...

a <- list(m2, m2, m2, m2)
mapply(cbind, a, m = 2)
#       [,1] [,2] [,3] [,4]
#  [1,]    1    1    1    1
#  [2,]    2    2    2    2
#  [3,]    3    3    3    3
#  [4,]    4    4    4    4
#  [5,]    5    5    5    5
#  [6,]    6    6    6    6
#  [7,]    7    7    7    7
#  [8,]    8    8    8    8
#  [9,]    2    2    2    2
# [10,]    2    2    2    2

我找不到任何关于为什么会发生这种情况的解释或可能的解决方法(输出将是与上面第一个示例格式相似的列表)?

这正是mapplyMap之间的区别,mapply默认有simplify = TRUE参数,这意味着

SIMPLIFY - logical or character string; attempt to reduce the result to a vector, matrix or higher dimensional array; see the simplify argument of sapply.

因此,在这种情况下,要获得与第一个示例相同的输出,我们应该使用 Map

Map(cbind, a, m = 2)

#[[1]]
#     A B C D m
#[1,] 1 3 5 7 2
#[2,] 2 4 6 8 2

#[[2]]
#     A B C D m
#[1,] 1 3 5 7 2
#[2,] 2 4 6 8 2

#[[3]]
#     A B C D m
#[1,] 1 3 5 7 2
#[2,] 2 4 6 8 2

#[[4]]
#     A B C D m
#[1,] 1 3 5 7 2
#[2,] 2 4 6 8 2