【发布时间】:2018-01-10 03:09:23
【问题描述】:
比方说,在 R 中,我有一个数据框字母、数字和动物,我想以图形方式检查这三者之间的关系。我可以做类似的事情。
library(dplyr)
library(ggplot2)
library(gridExtra)
set.seed(33)
my_df <- data.frame(
letters = c(letters[1:10], letters[6:15], letters[11:20]),
animals = c(rep('sheep', 10), rep('cow', 10), rep('horse', 10)),
numbers = rnorm(1:30)
)
ggplot(my_df, aes(x = letters, y = numbers)) + geom_point() +
facet_wrap(~animals, ncol = 1, scales = 'free_x')
但是,我希望 x 轴的顺序取决于 y 轴的顺序。根据example,这很容易在没有方面的情况下完成。 我什至可以为每只动物制作一个有序的图形,然后将它们与 grid.arrange 绑定在一起,如example
my_df_shp <- my_df %>% filter(animals == 'sheep')
my_df_cow <- my_df %>% filter(animals == 'cow')
my_df_horse <- my_df %>% filter(animals == 'horse')
my_df_shp1 <- my_df_shp %>% mutate(letters = reorder(letters, numbers))
my_df_cow1 <- my_df_cow %>% mutate(letters = reorder(letters, numbers))
my_df_horse1 <- my_df_horse %>% mutate(letters = reorder(letters, numbers))
p_shp <- ggplot(my_df_shp1, aes(x = letters, y = numbers)) + geom_point()
p_cow <- ggplot(my_df_cow1, aes(x = letters, y = numbers)) + geom_point()
p_horse <- ggplot(my_df_horse1, aes(x = letters, y = numbers)) + geom_point()
grid.arrange(p_shp, p_cow, p_horse, ncol = 1)
不过,我并不特别喜欢这种解决方案,因为它不容易推广到有很多方面的情况。
我宁愿做类似的事情 ggplot(my_df, aes(x = y_ordered_by_facet(letters, by = numbers), y = numbers)) + geom_point() + facet_wrap(~animals, ncol = 1, scales = 'free_x')
其中 y_ordered 是一些函数,它巧妙地将字母因子排序为与数字相同的顺序。
接近这个但似乎不太有效的东西是
ggplot(my_df, aes(x = reorder(letters, numbers), y = numbers)) +
geom_point() + facet_wrap(~animals, ncol = 1, scales = 'free_x')
这不太奏效,因为顺序最终会在刻面包装之前而不是之后生效,因此每个面板的标签顺序并不完全正确。
有什么聪明的想法吗?
【问题讨论】: