Converta os valores em uma coluna em nomes de linha em um quadro de dados existente em R

108

Eu gostaria de converter os valores em uma coluna de um quadro de dados existente em nomes de linhas. É possível fazer isso sem exportar o quadro de dados e depois reimportá-lo com uma row.names =chamada?

Por exemplo, eu gostaria de converter:

 > 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

para dentro:

> 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

obrigado

DQdlM
fonte

Respostas:

135

Isso deve fazer:

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

Resumindo, não, não há alternativa para reatribuir.

Editar: me corrigindo, também é possível fazer no local: atribuir atributos de nome de domínio e remover coluna:

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> 
Dirk Eddelbuettel
fonte
4
> rownames (df) <- df [, 1] Erro em row.names<-.data.frame( *tmp*, valor = valor): comprimento inválido de 'row.names' Além disso: Mensagem de aviso: Definir nomes de linha em uma tabela está obsoleto.
user3673
36

A partir de 2016, você também pode usar o tidyverse.

library(tidyverse)
samp %>% remove_rownames %>% column_to_rownames(var="names")
Joe
fonte
1
Mais especificamente, étibble::column_to_rownames
Ott Toomet
1
Recebo um aviso "A definição de nomes de linhas em uma tabela está obsoleta"
Quantum7
1
a visualização do tibble não mostra nomes de domínio, no entanto, para vê-lo você precisa canalizá-lo para as.data.frame ()samp %>% remove_rownames %>% column_to_rownames(var="names") %>% as.data.frame()
Matteo
22

em uma linha

> samp.with.rownames <- data.frame(samp[,-1], row.names=samp[,1])
Nigelhenry
fonte
11

Você pode executar isso em 2 instruções simples:

row.names(samp) <- samp$names
samp[1] <- NULL
victor8910
fonte
Funciona em R 3.5.3
TheSciGuy
5

Parece que o one-liner ficou ainda mais simples ao longo da linha (atualmente usando 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)

A coluna usada para nomes de linha é removida automaticamente.

stragu
fonte