我有一个data.frame与字符数据,我想最终与矩阵具有相同的列标题,但计数为每个值。到目前为止,我可以得到我想要的维度的空矩阵,但是当我尝试用计数填充myMatrix
时,它不起作用。矩阵分配在lapply中失败
myData <- data.frame(a=LETTERS[5:8], b=LETTERS[6:9], c=rep(LETTERS[5:6],2), d=rep(LETTERS[7],4))
# a b c d
# 1 E F E G
# 2 F G F G
# 3 G H E G
# 4 H I F G
myValues <- sort(unique(unlist(myData))) # E F G H I
myList <- lapply(myData, table)
myMatrix <- matrix(nrow=length(myValues), ncol=length(myList), dimnames=list(myValues,names(myList)))
# a b c d
# E NA NA NA NA
# F NA NA NA NA
# G NA NA NA NA
# H NA NA NA NA
# I NA NA NA NA
到目前为止好。这是没有做什么,我期待的部分:
lapply(seq_along(myList), function(i) {myMatrix[names(myList[[i]]),names(myList[i])] <- myList[[i]]})
它返回正确的价值观,但myMatrix
还是满的NAS。奇怪的是,这一个工程:
myMatrix[names(myList[[2]]),names(myList[2])] <- myList[[2]]
# a b c d
# E NA NA NA NA
# F NA 1 NA NA
# G NA 1 NA NA
# H NA 1 NA NA
# I NA 1 NA NA
为什么是分配给myMatrix
失败中lapply
以及如何我可以得到它的工作(没有for
循环)?
你得到你想要的东西,如果你更换'''<-'''第二'''lapply'''与'''<< - ' ''。见''?“<< - ”'''。这是否是一个好主意是一个不同的问题。 – orizon