Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
381 views
in Technique[技术] by (71.8m points)

r - How can I sort a data.frame with only one column, without losing rownames?

data = c(1,2,3,4)
names = c("foo", "bar", "baz", "yak")
d = data.frame(data, row.names=names)

This returns:

    data
foo    1
bar    2
baz    3
yak    4

Now, I'd like to sort this dataframe by the column, without losing the row names attached. So, my result would be:

    data
yak    4
baz    3
bar    2
foo    1

I've already tried the following:

  • d[order(-d$data),], which of course only gives me the one-dimensional list.

  • arrange(d, desc(data)) from the plyr package, which drops the row names.

  • Find out the order with o = order(-d$data), then reconstruct the frame with

    data.frame(d[o,], row.names=rownames(d)[o])
    

    … which still leaves me with the wrong column name.

Is there any sane way to do this?

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

You were close with your first attempt, just forgot about using drop = FALSE:

> d[order(-d$data), , drop = FALSE]
    data
yak    4
baz    3
bar    2
foo    1

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...