Ich versuche arrange_()
mit String-Eingabe und in einer der Spalten in absteigender Reihenfolge zu verwenden.arrange_() mehrere Spalten in absteigender Reihenfolge
library(dplyr) # R version 3.3.0 (2016-05-03) , dplyr_0.4.3
# data
set.seed(1)
df1 <- data.frame(grp = factor(c(1,2,1,2,1)),
x = round(runif(5,1,10), 2))
# grp x
# 1 1 3.39
# 2 2 4.35
# 3 1 6.16
# 4 2 9.17
# 5 1 2.82
Unten ist das, was ich erreichen müssen:
df1 %>% arrange(grp, -x)
df1 %>% arrange(grp, desc(x))
# grp x
# 1 1 6.16
# 2 1 3.39
# 3 1 2.82
# 4 2 9.17
# 5 2 4.35
In meinem Fall zweiten Spalte ist eine Zeichenkette:
#dynamic string
myCol <- "x"
#failed attempts
df1 %>% arrange_("grp", desc(myCol))
Error: incorrect size (1), expecting : 5
df1 %>% arrange_("grp", "desc(myCol)")
Error: object 'myCol' not found
df1 %>% arrange_(c("grp", "desc(myCol)"))
#wrong output
# grp x
# 1 1 3.39
# 2 1 6.16
# 3 1 2.82
# 4 2 4.35
# 5 2 9.17
fand ich ähnliche Lösung here, konnte es aber nicht funktioniert:
df1 %>% arrange_(.dots = c("grp", "desc(myCol)"))
Error: object 'myCol' not found
Fühlt ich etwas sehr offensichtlich fehle, Ideen?
Ja, das sind gute Alternativen, wünschte, es gäbe eine schönere Lösung, Paste zu vermeiden. – zx8754
@ zx8754 Ich habe eine Option mit 'interp' hinzugefügt, aber ich denke, die mit' paste' ist kompakt – akrun
Einverstanden, Paste scheint wie ein Weg zu gehen, 'interp' lässt es noch schlimmer aussehen (nichts für ungut). – zx8754