【发布时间】:2015-11-11 13:43:01
【问题描述】:
我有很多来自不同网站的数据。因此,我想重命名colnames 选择变量名称而不是矩阵中的数字位置。这是来自一个站点的矩阵的想法:
mdat <- matrix(c(rnorm(5,100), rnorm(5, 15), rnorm(5, 0.5), rnorm(5,0.1), rnorm(5,40)), nrow = 5, ncol = 5, byrow = F,
dimnames = list(c(2011:2015), c("Pre", "Temp", "Magnesium", "Zinc", "Hum")))
然后我想只重命名特定的colnames,将“镁”改成“镁”,将“锌”改成“锌”。
当我使用数字索引时,它可以完美运行:
colnames(mdat)[3:4] <- c("Zn", "Mg")
但我想知道如何按列名执行相同的操作,因为在我的不同矩阵中,这些变量位于不同的列位置。我试过了,但我得到一个错误:
colnames(mdat)[c("Zinc", "Magnesium")] <- c("Zn", "Mg")
Error in `colnames<-`(`*tmp*`, value = c("Pre", "Temp", "Magnesium", "Zinc", :
length of 'dimnames' [2] not equal to array extent
你能告诉我解决这个问题的方法吗?
谢谢
【问题讨论】:
-
您可能需要使用
%in%或match即colnames(mdat)[colnames(mdat) %in% c('Zinc', 'Magnesium')] <- c('Zn', 'Mg')还有match会更准确