r - 为什么在使用 ggplot 时我的条形图没有正确重新排列?
问题描述
所以我用这段代码制作了这个条形图,条形按降序排列,太棒了!
na.omit(insect_tally_native_ranges)%>%
group_by(native_ranges)%>%
dplyr::summarise(freq=sum(n))%>%
ggplot(aes(x=reorder(native_ranges,freq),y=freq))+
geom_col(color="#CD4F39",fill="#CD4F39",alpha=0.8)+
coord_flip()+
labs(x="Native ranges",
y="Number of invasive insect arrivals",
title="Species by native ranges")+
theme_minimal()
现在我想做同样的事情,但通过一个名为 的变量进行分面Period
,这是代码:
ggplot(native_freq_period,
aes(y=reorder(native_ranges,freq),x=freq))+
geom_barh(stat= "identity",
color="#CD4F39",
fill="#CD4F39",
alpha=0.8)+
labs(x="Native ranges",
y="Number of invasive insect arrivals",
title="Species by native ranges")+
theme_minimal()+
facet_wrap(~Period)
但情节是这样的:
这很烦人,因为它与上面的代码相同,并且native_ranges
应该再次组织变量的级别。但相反,它给了我这个甚至不是字母顺序的混乱顺序。所以reorder
零件正在重新排序,但不是freq
!不明白。
这是数据:
structure(list(native_ranges = structure(c(6L, 10L, 11L, 7L,
3L, 5L, 1L, 1L, 8L, 6L, 3L, 5L, 2L, 4L, 5L, 7L, 7L, 7L, 8L, 9L,
11L), .Label = c("Afrotropic", "Afrotropic/Neotropic", "Australasia",
"Australasia/Neotropic", "Indomalaya", "Nearctic", "Neotropic",
"Neotropic/Nearctic", "Neotropic/Nearctic/Australasia", "Palearctic",
"Palearctic/Indomalaya"), class = "factor"), Period = structure(c(4L,
4L, 4L, 4L, 4L, 4L, 3L, 4L, 4L, 3L, 3L, 3L, 4L, 4L, 2L, 1L, 2L,
3L, 2L, 4L, 3L), .Label = c("1896-1925", "1926-1955", "1956-1985",
"1986-2018"), class = "factor"), freq = c(21L, 13L, 12L, 11L,
10L, 10L, 4L, 4L, 4L, 3L, 2L, 2L, 1L, 1L, 1L, 1L, 1L, 1L, 1L,
1L, 1L)), row.names = c(NA, -21L), class = c("grouped_df", "tbl_df",
"tbl", "data.frame"), vars = "native_ranges", drop = TRUE, indices = list(
6:7, 12L, c(4L, 10L), 13L, c(5L, 11L, 14L), c(0L, 9L), c(3L,
15L, 16L, 17L), c(8L, 18L), 19L, 1L, c(2L, 20L)), group_sizes = c(2L,
1L, 2L, 1L, 3L, 2L, 4L, 2L, 1L, 1L, 2L), biggest_group_size = 4L, labels = structure(list(
native_ranges = structure(1:11, .Label = c("Afrotropic",
"Afrotropic/Neotropic", "Australasia", "Australasia/Neotropic",
"Indomalaya", "Nearctic", "Neotropic", "Neotropic/Nearctic",
"Neotropic/Nearctic/Australasia", "Palearctic", "Palearctic/Indomalaya"
), class = "factor")), row.names = c(NA, -11L), class = "data.frame", vars = "native_ranges", drop = TRUE))
解决方案
在绘图之前,您必须先安排变量的顺序。由于您没有提供任何可重现的数据,我正在使用以下数据
drugs <- data.frame(drug = c("a", "b", "c"), effect = c(4.2, 9.7, 6.1))
ggplot(drugs, aes(drug, effect)) +
geom_col()
现在改变变量使用的顺序factor
drugs$drug <- factor(drugs$drug,levels = c("b","a","c")) #This is the order I want
ggplot(drugs, aes(drug, effect)) +
geom_col()
在这里,我手动提供了levels
in 。factor
您可以手动提供它们,也可以先单独对变量的顺序进行排序并提供。见下文,
drugs$drug <- factor(drugs$drug,levels = drugs[order(drugs$effect),]$drug)
ggplot(drugs, aes(drug, effect)) +
geom_col()
这也应该适用facet_wrap
。
推荐阅读
- flutter - 正确布局列和扩展的小部件,没有有限的宽度
- c - 程序在捕获信号时冻结
- reactjs - 按下回车后如何请求远程数据?(mbrn/材料表)
- angular - 三个 js OBJ 加载器创建在 Angular 中的 typesecript 中不起作用
- angular - 传播类型只能从对象类型创建角度错误角度
- html - display flex 水平显示图像和完整段落,但无法正常工作
- javascript - 未捕获的 TypeError: $(...).fullCalendar 不是函数错误
- css - 如果选择了输入单选按钮,则显示 div
- mysql - 更新和选择 MYSQL
- javascript - 单击 youtube 播放按钮后触发事件