我知道如果我有一个包含多于一列的数据帧,那么我可以使用

colnames(x) <- c("col1","col2")

重命名列。如果只有一列,该怎么做呢? 意思是只有一列的向量或数据帧。

例子:

trSamp <- data.frame(sample(trainer$index, 10000))
head(trSamp )
#   sample.trainer.index..10000.
# 1                      5907862
# 2                      2181266
# 3                      7368504
# 4                      1949790
# 5                      3475174
# 6                      6062879

ncol(trSamp)
# [1] 1
class(trSamp)
# [1] "data.frame"
class(trSamp[1])
# [1] "data.frame"
class(trSamp[,1])
# [1] "numeric"
colnames(trSamp)[2] <- "newname2"
# Error in names(x) <- value : 
#   'names' attribute [2] must be the same length as the vector [1]

当前回答

让df是你拥有的数据框架,col名称为myDays和temp。 如果你想把"myDays"重命名为"Date"

library(plyr)
rename(df,c("myDays" = "Date"))

或者用管子,你可以

dfNew      <- df %>% 
  plyr::rename(c("myDays" = "Date"))

其他回答

colnames(trSamp)[2] <- "newname2"

尝试设置第二列的名称。对象只有一列,因此该命令会抛出错误。这就足够了:

colnames(trSamp) <- "newname2"

你也可以尝试'Hmisc'包中的'upData'。

图书馆(Hmisc)

trSamp = upData(trSamp, rename=c(sample.trainer.index..10000。= ' newname2 '))

colnames(df)[colnames(df) == 'oldName'] <- 'newName'

让df是你拥有的数据框架,col名称为myDays和temp。 如果你想把"myDays"重命名为"Date"

library(plyr)
rename(df,c("myDays" = "Date"))

或者用管子,你可以

dfNew      <- df %>% 
  plyr::rename(c("myDays" = "Date"))

如果你知道你的数据帧只有一列,你可以使用: names(trSamp) <- "newname2"