[r] data.frame에서 단일 열의 이름을 바꾸는 방법은 무엇입니까?

열이 두 개 이상인 데이터 프레임이 있으면 사용할 수 있습니다.

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'

이 코드는 거의 다음을 수행합니다.

  1. names(df) 의 모든 이름을 살펴 본다 df
  2. [names(df) == old.var.name] 확인할 변수 이름을 추출합니다.
  3. <- 'new.var.name' 새 변수 이름을 할당합니다.

답변

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


답변

이것은 오래된 질문이지만 이제 패키지 setnames에서 사용할 수 있다는 점에 주목할 가치가 있습니다 data.table.

library(data.table)

setnames(DF, "oldName", "newName")

# or since the data.frame in question is just one column: 
setnames(DF, "newName")

# And for reference's sake, in general (more than once column)
nms <- c("col1.name", "col2.name", etc...)
setnames(DF, nms)


답변

이것은 또한 Hadley의 plyr패키지와 rename기능을 사용하여 수행 할 수 있습니다 .

library(plyr)
df <- data.frame(foo=rnorm(1000))
df <- rename(df,c('foo'='samples'))

위치를 알 필요없이 이름으로 이름을 바꾸고 한 번에 여러 이름을 바꿀 수 있습니다. 예를 들어 병합을 수행 한 후에는 다음과 같이 끝날 수 있습니다.

  letterid id.x id.y
1       70    2    1
2      116    6    5
3      116    6    4
4      116    6    3
5      766   14    9
6      766   14   13

다음을 사용하여 한 단계로 이름을 바꿀 수 있습니다.

letters <- rename(letters,c("id.x" = "source", "id.y" = "target"))

  letterid source target
1       70      2      1
2      116      6      5
3      116      6      4
4      116      6      3
5      766     14      9
6      766     14     13


답변

열 이름을 바꾸는 가장 좋은 방법은 다음과 같이 dplyr 패키지 를 사용하는 것입니다.

require(dplyr)
df = rename(df, new_col01 = old_col01, new_col02 = old_col02, ...)

모든 데이터 세트에서 하나 이상의 열 이름을 바꾸는 경우에도 동일하게 작동합니다.


답변

데이터 프레임 열 이름을 하나씩 바꾸는 다음 스타일이 마음에 듭니다.

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

어디

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

특정 열의 인덱스로 반환합니다.