data.frame内の単一の列の名前を変更するにはどうすればよいですか?


335

2列以上のデータフレームがある場合は、

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

列の名前を変更します。列が1つだけの場合、どうすればよいですか?1列のみのベクトルまたはデータフレームを意味します。

例:

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。あなたが試みた例は非常に役に立ちます。
ジョシュアウルリッヒ

2
「colnames(x)[1] <-'newname2'」を使用すると機能します
screechOwl

回答:


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

2番目の列の名前を設定しようとします。オブジェクトには列が1つしかないため、コマンドはエラーをスローします。これで十分です:

colnames(trSamp) <- "newname2"

1
。@ JoshuaUlrich -列名のようなものである場合、これは動作していないよう"A,B,C,X,Y,Z"、私はそれに名前を変更したい場所をY使用しますtestData[379] <- "Y"
Chetan Arvind Patil

575

これは、変数の正確な場所を覚えておく必要がない一般的な方法です。

# 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]実際に真/偽の値を持つベクトルを返すことを指定する価値があると思います。したがって、たとえば正規表現が使用されている場合、複数の列名が変更される可能性があります。
mikyatope 2013

3
正規表現の結果については、などを使用しますnames(df) = sub('pattern', 'replacement', names(df))。そうしないと、複数の列を同じ名前に設定しようとするでしょう。
私たちは全員モニカです。

40
複雑な感情...完璧なプログラミング言語がたくさんある完璧な世界では、単一の列の名前を変更するためにこれだけ多くのキーストロークが本当に必要ですか?私はRを愛していますが、このような理由でRを絞殺したい場合があります。
tumultous_rooster

4
これにベースのラッパー関数がないのはなぜですか?
ifly6 '06 / 09/18

1
みんなが望んでいること!今はわかりませんが、当時はベースにラッパーがありませんでした
Side_0o_Effect

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

2
このソリューションが好きなのは、列の名前を名前で参照できるためです。列の番号を知る必要はありません。多数の機能に適しています。
サイバネティック

1
質問とこの回答に小さな拡張があります。「snp」という文字が含まれている列を持つデータフレームがあります。名前を'Marker'に変更します。しかし、私はそうするために正規表現を使いたいです。colnames(GWASDATA_RAWSELECTION)[colnames(GWASDATA_RAWSELECTION)=="^snp$"] <- "Marker"列の名前が変更されていないため、どうやら私が持っているコードに欠陥があります。私が行う場合names(GWASDATA_RAWSELECTION)[names(GWASDATA_RAWSELECTION)=="snp"] <- "Marker"、それがされて名前を変更しました。何が欠けていますか?
Sander W. van der Laan

76

これは古い質問ですがsetnamesdata.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

これはplyr、Hadleyのパッケージと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

次のコマンドを使用して、1つの手順で名前を変更できます。

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、2015

36

列の名前を変更する最良の方法は、次のようなdplyrパッケージを使用することです

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

データセット内の1つまたは複数の列の名前を変更する場合も同様に機能します。


12

データフレームの列名を1つずつ変更する次のスタイルが好きです。

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

どこ

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

特定の列のインデックスによって返されます。


1
ユーザーに実際の古い名前を使用する機会を与えるための+1 :)

1
@zongshiwujieのソリューションとの違いは何ですか?
buhtz

which()必要ありません。
sindri_baldur 2018

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.varsgdataパッケージ。

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 2017年

4

試してください:

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

8
これは、OPが(編集で)尋ねたエラーをスローしたものです。データフレームには列が1つしかないため、機能しません。

。@ 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 2017

ワンライナーではないことを除けば、あなたの答えには何の問題もありません。
count0

@ count0に感謝します。質問にコメントするためのマナポイントや何かを持っていることは実際に意味があります。私がまだできていないことです。新しいスキルセットを習得するときに、フォローアップの質問が役立つ場合があります。再び。TY。
Scottieie 2017年

1
これを使用するには、すべての列に名前を付ける必要があります。
Arpit Sisodia 2017

rename関数はどのパッケージからのものですか?
ディエゴ

3

データフレームに列が1つしかないことがわかっている場合は、以下を使用できます。 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

別の例:「句読点」の存在に関する部分一致:

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_withends_withcontainsmatches、...)。

.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.integeris.numericis.factor...

is.integery)の例:

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:in names [cols] <-.fn(names [cols]、...) :交換するアイテムの数が交換する長さの倍数ではありません

これはseq_along(.)、replace関数との不整合にすぎないため、関係ありません。


-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.