R:dplyr:如何在不知道名字的情况下引用arrange()中的列?

时间:2015-12-03 19:20:52

标签: r dplyr

dplyr是一个很棒的包,我尝试在我的代码中使用一致。 它产生非常易读的代码。

select(3,4)功能允许我选择第三和第四列。

我想在arrange()方法中使用相同的方法。 在SQL中,通过数字或名称可以互换地工作。 (很棒)

不幸的是,我只能在dplyr :: arrange()

中使用名称

如果我知道我需要通过第3列订购(安排),是否可以使用代码模式。在我的代码中,该列的名称将更改,但我将始终需要第3列的顺序。 (职位不会)

在此处查看问题:

> head(mtcars)
                   mpg cyl disp  hp drat    wt  qsec vs am gear carb
Mazda RX4         21.0   6  160 110 3.90 2.620 16.46  0  1    4    4
Mazda RX4 Wag     21.0   6  160 110 3.90 2.875 17.02  0  1    4    4
Datsun 710        22.8   4  108  93 3.85 2.320 18.61  1  1    4    1
Hornet 4 Drive    21.4   6  258 110 3.08 3.215 19.44  1  0    3    1
Hornet Sportabout 18.7   8  360 175 3.15 3.440 17.02  0  0    3    2
Valiant           18.1   6  225 105 2.76 3.460 20.22  1  0    3    1
> library(sqldf)
> sqldf('select * from mtcars order by 2,3 limit 10')
    mpg cyl  disp  hp drat    wt  qsec vs am gear carb
1  33.9   4  71.1  65 4.22 1.835 19.90  1  1    4    1
2  30.4   4  75.7  52 4.93 1.615 18.52  1  1    4    2
3  32.4   4  78.7  66 4.08 2.200 19.47  1  1    4    1
4  27.3   4  79.0  66 4.08 1.935 18.90  1  1    4    1
5  30.4   4  95.1 113 3.77 1.513 16.90  1  1    5    2
6  22.8   4 108.0  93 3.85 2.320 18.61  1  1    4    1
7  21.5   4 120.1  97 3.70 2.465 20.01  1  0    3    1
8  26.0   4 120.3  91 4.43 2.140 16.70  0  1    5    2
9  21.4   4 121.0 109 4.11 2.780 18.60  1  1    4    2
10 22.8   4 140.8  95 3.92 3.150 22.90  1  0    4    2
> #arrange(mtcars,cyl,disp)
> #this works but I have to use names to refer to the columns :-(

喜欢安排(mtcars,3)。例如,安排(mtcars,名称(mtcars)[3])不起作用。 : - (

2 个答案:

答案 0 :(得分:4)

我们可以使用arrange_

arrange_(mtcars, names(mtcars)[3])

答案 1 :(得分:0)

为dplyr 1.0更新:

arrange(mtcars, across(names(mtcars)[3]))