slhck
slhck

Reputation: 38652

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:

Is there any sane way to do this?

Upvotes: 43

Views: 25316

Answers (1)

flodel
flodel

Reputation: 89057

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

Upvotes: 48

Related Questions