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


335

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

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]

4
@aix의 솔루션은 1 열 data.frame에 대해 작동합니다. drop=TRUE기본 인수에 의해 혼동되어 ["1 열"객체가 벡터로 변환되고 벡터에는 없습니다 colnames. 시도한 것의 예가 매우 도움이 될 것입니다.
Joshua Ulrich

2
당신이 '-'newname2 'COLNAMES (X) [1] < "사용하는 경우 그것은 작동
screechOwl

답변:


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

두 번째 열의 이름을 설정하려고 시도합니다. 객체에는 하나의 열만 있으므로 명령에서 오류가 발생합니다. 이것으로 충분합니다 :

colnames(trSamp) <- "newname2"

1
. @ JoshuaUlrich-열 이름이을 사용하여 "A,B,C,X,Y,Z"이름을 바꾸려 는 위치 와 같은 경우 작동하지 않는 것 같습니다 . YtestData[379] <- "Y"
Chetan Arvind Patil

576

이것은 변수의 정확한 위치를 기억할 필요가없는 일반적인 방법입니다.

# 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' 새 변수 이름을 할당합니다.

5
나는 또한 R과 함께 아주 새롭고이 솔루션을 좋아했습니다! 실제로 그 기능을 확인했으며 [names(df) == old.var.name]실제로 true / false 값을 가진 벡터를 반환하도록 지정할 가치가 있다고 생각 합니다. 따라서 예를 들어 정규식을 사용하는 경우 여러 열 이름을 변경할 수 있습니다.
mikyatope

3
정규식 결과를 얻으려면 다음과 같은 것을 사용하십시오 names(df) = sub('pattern', 'replacement', names(df)). 그렇지 않으면 여러 열을 같은 이름으로 설정하려고합니다.
우리 모두 모니카

40
완벽한 프로그래밍 언어가 풍부한 완벽한 세계에서 혼합 된 감정은 단일 열의 이름을 바꾸려면이 많은 키 입력이 실제로 필요합니까? 나는 R을 좋아하지만 때로는 이러한 유형의 이유로 그것을 교살하고 싶습니다.
tumultous_rooster 1

4
이것에 대한 래퍼 함수가 기본적으로 없습니까?
ifly6

1
우리 모두가 바라는 방법! 나는 지금에 대해 모른다. 그러나 당시에는베이스에 어떤 래퍼도 없었다
Side_0o_Effect

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

2
나는 어떤 숫자 열인지 알아야하는 것이 아니라 이름으로 열 이름을 참조 할 수 있기 때문에이 솔루션을 좋아합니다. 더 많은 수의 기능에 적합합니다.
Cybernetic

1
질문 과이 답변에 대한 작은 확장이 있습니다. 'snp' 라는 문자가있는 열이있는 데이터 프레임이 있습니다. 이름을 'Marker' 로 바꾸고 싶습니다 . 그러나 정규 표현식 을 사용하여 그렇게 하고 싶습니다 . 분명히 내가 가지고있는 코드에는 결함이 있습니다 : colnames(GWASDATA_RAWSELECTION)[colnames(GWASDATA_RAWSELECTION)=="^snp$"] <- "Marker". 열의 이름이 바뀌지 않았기 때문입니다. 그렇게 names(GWASDATA_RAWSELECTION)[names(GWASDATA_RAWSELECTION)=="snp"] <- "Marker"하면 이름 바뀝니다. 내가 무엇을 놓치고 있습니까?
샌더 W. 반 데어 Laan

76

이것은 오래된 질문이지만 이제 패키지 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)

6
또는 setNames기지 R에서
PatrickT

53

이것은 또한 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

7
rename이제 dplyr패키지 의 기능 이기도합니다.
Sam Firke

36

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

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

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


12

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

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

어디

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

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


1
사용자에게 실제 이전 이름을 사용할 수있는 기회를 제공 한 +1 :)

1
@zongshiwujie의 솔루션과 비교하여 차이점은 무엇입니까?
buhtz

which()필요가 없습니다.
sindri_baldur

12

단일 열의 이름을 바꾸는 가장 편리한 방법은 다음을 사용하는 것입니다 dplyr::rename_at.

library(dplyr)
cars %>% rename_at("speed",~"new") %>% head     
cars %>% rename_at(vars(speed),~"new") %>% head
cars %>% rename_at(1,~"new") %>% head

#   new dist
# 1   4    2
# 2   4   10
# 3   7    4
# 4   7   22
# 5   8   16
# 6   9   10
  • 파이프 체인에서 잘 작동
  • 이름이 변수에 저장 될 때 편리
  • 이름 또는 열 인덱스와 함께 작동
  • 깨끗하고 컴팩트

6

패키지 rename.vars에서 사용할 수 있습니다 gdata.

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


이것은 가장 쉬운 방법입니다. 감사합니다. dplyr 패키지에 문제가있었습니다.
DannyB

4

시험:

colnames(x)[2] <- 'newname2'

8
이것이 OP가 편집에서 요청한 오류를 발생시킨 것입니다. 데이터 프레임에 열이 하나만 있기 때문에 작동하지 않습니다.

. @ NPE-열 이름이 "A,B,C,X,Y,Z"Y사용하여 이름을 바꾸려 는 위치 와 같은 경우 작동하지 않는 것 같습니다 testData[379] <- "Y".
Chetan Arvind Patil

4

이것은 이미 거기에있을 가능성이 있지만 솔루션을 검색하는 동안 필드 이름 바꾸기로 놀고 있었고 기발한 시도를했습니다. 내 목적을 위해 일했다.

Table1$FieldNewName <- Table1$FieldOldName
Table1$FieldOldName <- NULL

편집은 여기서 시작합니다.

이것은 잘 작동합니다.

df <- rename(df, c("oldColName" = "newColName"))

저를 표시 한 사람에게는 괜찮습니다. 그러나이 작업을 처음 접했으므로 아마도 대답에 어떤 문제가 있는지 깨달을 수 있습니다.
Scottieie

귀하의 답변에는 oneliner가 아닌 것 외에는 아무런 문제가 없습니다. 그것은 그의 적개심을 정당화 할 용기가없는 적대적인 SO 사용자였습니다.
count0

감사합니다 @ count0. 실제로 아직 할 수 없었던 질문에 대한 마나 점이나 의견이 있으면 의미가 있습니다. 새로운 스킬 셋을 배우면 어떤 경우에는 후속 질문을하는 것이 좋습니다. 다시. TY.
Scottieie

1
이를 사용하려면 모든 열에 이름을 지정해야합니다.
Arpit Sisodia

어떤 패키지에서 rename기능이 제공됩니까?
디에고

3

데이터 프레임에 열이 하나만 있다는 것을 알고 있다면 다음을 사용할 수 있습니다. names(trSamp) <- "newname2"


3

'Hmisc'패키지에서 'upData'를 시도 할 수도 있습니다.

library(Hmisc)

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


아주 좋아요! 한 번에 더 많은 열의 이름을 바꿀 수도 있습니다. trSamp = upData (trSamp, rename = c (sample.trainer.index..10000. = 'newname2, AnotherColumnName ='RenameThisColumn '))
FraNut

0

OP의 질문은 훌륭하고 진정으로 답변되었습니다. 그러나 다음과 같은 상황에서 유용한 트릭이 있습니다. 데이터 프레임에서의 위치에 관계없이 열 이름의 부분 일치 :

이름의 부분 일치 :

d <- data.frame(name1 = NA, Reported.Cases..WHO..2011. = NA, name3 = NA)
##   name1 Reported.Cases..WHO..2011. name3
## 1    NA                         NA    NA
names(d)[grepl("Reported", names(d))] <- "name2"
##   name1 name2 name3
## 1    NA    NA    NA

또 다른 예 : "punctuation"이있을 경우 부분 일치 :

d <- data.frame(name1 = NA, Reported.Cases..WHO..2011. = NA, name3 = NA)
##   name1 Reported.Cases..WHO..2011. name3
## 1    NA                         NA    NA
names(d)[grepl("[[:punct:]]", names(d))] <- "name2"
##   name1 name2 name3
## 1    NA    NA    NA

이것들은 내가 오늘 다루어야 할 예였으며, 나눌 가치가 있다고 생각했습니다.



0

rename_with함수를 사용 하여 열의 이름을 바꾸는 데 사용할 수 있습니다 ( stringr예 : 함수).

다음 데이터를 고려하십시오 df_1.

df_1 <- data.frame(
  x = replicate(n = 3, expr = rnorm(n = 3, mean = 10, sd = 1)), 
  y = sample(x = 1:2, size = 10, replace = TRUE)
)

names(df_1)

#[1] "x.1" "x.2" "x.3" "y" 

다음 과 같이 모든 변수의 이름을 바꾸십시오 dplyr::everything().

library(tidyverse)

df_1 %>% 
  rename_with(.data = ., .cols = everything(.), 
              .fn = str_replace, pattern = '.*', 
              replacement = str_c('var', seq_along(.), sep = '_')) %>% 
  names()

#[1] "var_1" "var_2" "var_3" "var_4"

로 이름 바꾸기 이름 입자 일부와 dplyr동사 ( starts_with, ends_with, contains, matches, ...).

.( x변수)를 사용한 예 :

df_1 %>% 
  rename_with(.data = ., .cols = contains('.'), 
              .fn = str_replace, pattern = '.*', 
              replacement = str_c('var', seq_along(.), sep = '_')) %>% 
  names()

#[1] "var_1" "var_2" "var_3" "y"

로 이름 바꾸기 클래스 클래스 테스트의 많은 기능과 같은 is.integer, is.numeric, is.factor...

is.integer( y)를 사용한 예 :

df_1 %>% 
  rename_with(.data = ., .cols = is.integer, 
              .fn = str_replace, pattern = '.*', 
              replacement = str_c('var', seq_along(.), sep = '_')) %>% 
  names()

#[1] "x.1"   "x.2"   "x.3"   "var_1"

경고 :

경고 메시지 : 1 : stri_replace_first_regex (string, pattern, fix_replacement (replacement))에서 : 더 긴 오브젝트 길이는 더 짧은 오브젝트 길이의 배수가 아닙니다. 2 : names [cols] <-.fn (names [cols], ...) : 교체 할 품목 수가 교체 길이의 배수가 아님

seq_along(.)바꾸기 기능과 일치하지 않기 때문에 관련이 없습니다 .


-1

원하는 이름으로 데이터 프레임에 새 열을 추가하고 기존 열에서 데이터를 가져옵니다. 이처럼 :

dataf$value=dataf$Article1Order

그런 다음 이전 열을 제거합니다! 이처럼 :

dataf$Article1Order<-NULL

이 코드는 바보처럼 보일 수 있습니다! 그러나 그것은 완벽하게 작동합니다 ...


-1

다음 코드를 사용하여 열 이름을 원하는 새 이름으로 데이터 세트로 변경합니다. names (dataset) [index_value] <- "new_col_name"


당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.