Я усвідомлюю, що це стара, але, можливо, ця функція, яку я створив, корисна комусь там:
order_axis<-function(data, axis, column)
{
# for interactivity with ggplot2
arguments <- as.list(match.call())
col <- eval(arguments$column, data)
ax <- eval(arguments$axis, data)
# evaluated factors
a<-reorder(with(data, ax),
with(data, col))
#new_data
df<-cbind.data.frame(data)
# define new var
within(df,
do.call("<-",list(paste0(as.character(arguments$axis),"_o"), a)))
}
Тепер за допомогою цієї функції ви можете інтерактивно побудувати графік з ggplot2, як це:
ggplot(order_axis(df, AXIS_X, COLUMN_Y),
aes(x = AXIS_X_o, y = COLUMN_Y)) +
geom_bar(stat = "identity")
Як видно, order_axis
функція створює інший фрейм даних з новим стовпцем, названим таким же, але з а _o
в кінці. Цей новий стовпець має рівні у порядку зростання, тому ggplot2 автоматично розміщує в цьому порядку.
Це дещо обмежено (працює лише для символьних чи факторних та числових комбінацій стовпців та у порядку зростання), але я все ще вважаю це дуже корисним для побудови графіків на ходу.