如何在R中按第n列对数据框进行排序

3

我有两个具有相同列数的数据框。我正在编写一个函数,该函数需要将这两个数据框和一个整数n作为参数,并需要按其各自的第n列对每个数据集进行排序。基本上,如何通过不知道该列的标签来按其第n列对数据框进行排序?

2个回答

6
这里稍作修改,关于如何按列对数据框进行排序的回答: How to sort a dataframe by column(s)?
dd <- data.frame(b = factor(c("Hi", "Med", "Hi", "Low"), 
                            levels = c("Low", "Med", "Hi"), ordered = TRUE),
                 x = c("A", "D", "A", "C"), y = c(8, 3, 9, 9),
                 z = c(1, 1, 1, 2))

n <- 2
dd[ order(dd[[n]]), ]


    b x y z
1  Hi A 8 1
3  Hi A 9 1
4 Low C 9 2
2 Med D 3 1

或者,您可以使用colnames(dd)[n]查找标签,并将其与上述链接中的任何方法一起使用。


1
这里是dplyr的解决方案:
test_df <- data.frame(b = factor(c("Hi", "Med", "Hi", "Low"), 
                        levels = c("Low", "Med", "Hi"), ordered = TRUE),
                      x = c("A", "D", "A", "C"), y = c(8, 3, 9, 9),
                      z = c(1, 1, 1, 2))

n = 2

test_df <- test_df %>% 
  arrange(.[[n]])

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接