假设在 R 中,我有一个数据框 letters、numbers 和 animals,并且我想通过图形来检查它们之间的关系。可以使用以下代码:
这不太可行,因为顺序在分面包装之前就生效了,导致每个面板中的标签顺序不完全正确。
有什么聪明的想法吗?
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轴的顺序。在没有分面的情况下,这很容易做到,就像这个例子所示。 我甚至可以为每个动物制作一个有序的图形,然后使用grid.arrange将它们绑在一起,就像这个例子中的操作。
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')
这不太可行,因为顺序在分面包装之前就生效了,导致每个面板中的标签顺序不完全正确。
![almost ordered](https://istack.dev59.com/YIOhi.webp)