如何重命名data.frame中的单个列?

我知道如果我有超过1列的数据框,我可以使用

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]

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

尝试设置第二列的名称。 您的对象只有一列,所以该命令会引发错误。 这应该足够了:

colnames(trSamp) <- "newname2"

这是一种广义的方式,您不必记住变量的确切位置:

# 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'分配新的变量名称。

  • colnames(df)[colnames(df) == 'oldName'] <- 'newName'
    
    链接地址: http://www.djcxy.com/p/64895.html

    上一篇: How to rename a single column in a data.frame?

    下一篇: Changing column names of a data frame