我的数据框如下:
> df <- data.frame("A"=rnorm(26), "B"=rnorm(26),row.names=sample(letters,26))
然后,我希望将列B
作为向量使用不同的行顺序
> newOrder <- sample(letters,26)
> vec <- df[newOrder,"B"] #1
如何在{1}的单个语句中保留df
的正确rownames作为vec
的向量名?也就是说,无需这样做:
> names(vec) <- newOrder
答案 0 :(得分:4)
您可以使用setNames
> vec <- setNames(df[newOrder, "B"], newOrder)
> vec
q c a l g v
-0.44632045 0.80264068 -0.51574653 -1.57176346 0.16977483 -0.04916571
j z u b w p
0.95736262 -0.35259227 0.20451454 -0.03873499 0.62497872 1.26984233
f t o y n k
0.52851609 -0.37680593 -2.01770314 -0.94752793 0.64001006 1.72032405
d e m r s i
0.30731069 0.54537837 2.32968848 -0.43577586 -0.16144602 -0.12817791
x h
0.52822103 1.68236876