Преобразовать значения в столбце в имена строк в существующем фрейме данных в R - PullRequest
90 голосов
/ 05 апреля 2011

Я хотел бы преобразовать значения в столбце существующего фрейма данных в имена строк.Возможно ли это сделать без экспорта фрейма данных и последующего его импорта с помощью вызова row.names =?

Например, я хотел бы преобразовать:

 > samp 
     names Var.1 Var.2 Var.3
 1     A     1     5     0
 2     B     2     4     1
 3     C     3     3     2
 4     D     4     2     3
 5     E     5     1     4

в:

> samp.with.rownames 
     Var.1 Var.2 Var.3
A     1     5     0
B     2     4     1
C     3     3     2
D     4     2     3
E     5     1     4

спасибо

Ответы [ 5 ]

112 голосов
/ 05 апреля 2011

Это должно сделать:

samp2 <- samp[,-1]
rownames(samp2) <- samp[,1]

Короче говоря, нет альтернативы переназначению.

Редактировать: Исправляя себя, можно сделать это на месте: назначить атрибуты имени строки, а затем удалить столбец:

R> df<-data.frame(a=letters[1:10], b=1:10, c=LETTERS[1:10])
R> rownames(df) <- df[,1]
R> df[,1] <- NULL
R> df
   b c
a  1 A
b  2 B
c  3 C
d  4 D
e  5 E
f  6 F
g  7 G
h  8 H
i  9 I
j 10 J
R> 
27 голосов
/ 29 марта 2017

С 2016 года вы также можете использовать tidyverse.

library(tidyverse)
samp %>% remove_rownames %>% column_to_rownames(var="names")
20 голосов
/ 07 ноября 2013

в одну строку

> samp.with.rownames <- data.frame(samp[,-1], row.names=samp[,1])
5 голосов
/ 09 апреля 2018

Вы можете выполнить это в 2 простых операторах:

row.names(samp) <- samp$names
samp[1] <- NULL
1 голос
/ 28 марта 2019

Похоже, что однострочник стал еще проще (в настоящее время используется R 3.5.3):

# generate original data.frame
df <- data.frame(a = letters[1:10], b = 1:10, c = LETTERS[1:10])
# use first column for row names
df <- data.frame(df, row.names = 1)

Столбец, используемый для имен строк, автоматически удаляется.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...