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

use*_*rJT 2 r dplyr

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

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

我想在排列()方法中使用相同的方法。在 SQL 中,按数字或名称可以互换使用。(这很棒)

不幸的是,我只能使用 dplyr::arrange() 的名称

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

请参阅这里的问题:

> 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 :-(
Run Code Online (Sandbox Code Playgroud)

像排列(mtcars,3)这样的东西。例如,排列(mtcars,names(mtcars)[3])不起作用。:-(

akr*_*run 5

我们可以用arrange_

arrange_(mtcars, names(mtcars)[3])
Run Code Online (Sandbox Code Playgroud)

  • [这是小插图](https://cran.r-project.org/web/packages/dplyr/vignettes/nse.html) 解释 _ (3认同)