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

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()参数更容易 https://www.rdocumentation.org/packages/base/versions/3.6.2/topics/row%2Bcolnames

从数据帧中选择某一列

df <- data.frame(df[, c( "hhid","b1005", "b1012_imp", "b3004a")])

并按顺序重命名所选列,

colnames(df) <- c("hhid", "income", "cost", "credit")

检查名称和值以确定

names(df);head(df)

您可以使用重命名。gdata包中的Vars。

library(gdata)
df <- rename.vars(df, from = "oldname", to = "newname")

当你有多个变量名要修改,或者你想在变量名后面追加或预先添加一些文本时,这是特别有用的,你可以这样做:

df <- rename.vars(df, from = c("old1", "old2", "old3", 
         to = c("new1", "new2", "new3"))

有关将文本附加到变量名称子集的示例,请参阅: https://stackoverflow.com/a/28870000/180892

这是一种通用的方法,你不需要记住变量的确切位置:

# df = dataframe
# old.var.name = The name you don't like anymore
# new.var.name = The name you want to get

names(df)[names(df) == 'old.var.name'] <- 'new.var.name'

这段代码基本上完成了以下工作:

Names (df)查找df中所有的名称 [names(df) == old.var.name]提取你想检查的变量名 <- 'new.var.name'指定新的变量名。

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

图书馆(Hmisc)

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

我喜欢下一个样式来逐个重命名dataframe列名。

colnames(df)[which(colnames(df) == 'old_colname')] <- 'new_colname'

在哪里

which(colnames(df) == 'old_colname')

由指定列的索引返回。