ggplot2展示图中部分数据的小例子
2021-04-29 本文已影响0人
R语言数据分析指南
有时我们进行绘图的时候,只想展示一部分内容这时该如何操作,ggplot2里面当然有相应的语法,但是如果有R包能完成此工作岂不更好,gghighlight包的出现很好的解决了这一问题,感谢Hiroaki Yutani开发出如此好用的R包
data:image/s3,"s3://crabby-images/79352/793520fdd6a208b70d002620f11eed54f6704a6e" alt=""
下面通过几个小例子来介绍如何使用
安装
install.packages("gghighlight")
# install.packages("devtools")
devtools::install_github("yutannihilation/gghighlight")
加载R包
library(tidyverse)
library(gghighlight)
构建数据
d <- purrr::map_dfr(
letters,
~ data.frame(
idx = 1:400,
value = cumsum(runif(400, -1, 1)),
type = .,
flag = sample(c(TRUE, FALSE), size = 400, replace = TRUE),
stringsAsFactors = FALSE
)
)
ggplot(d) +
geom_line(aes(idx, value, colour = type))+
theme_minimal()
data:image/s3,"s3://crabby-images/6bc21/6bc21f2eeeac008f236626f2e172524efd1a8a52" alt=""
ggplot(d) +
geom_line(aes(idx, value, colour = type)) +
gghighlight(max(value) > 12)
data:image/s3,"s3://crabby-images/27c71/27c71d343fbd55aca2f9ccf1cf28451e33b256ae" alt=""
ggplot(d) +
geom_line(aes(idx, value, colour = type)) +
gghighlight(max(value) > 12) +
theme_minimal() +
facet_wrap(~ type)
data:image/s3,"s3://crabby-images/74ad2/74ad2a710f1723c04310b7f30fc697c95f2b2b95" alt=""
p <- ggplot(mtcars, aes(wt, mpg, colour = factor(cyl))) +
geom_point(size=4)
p
data:image/s3,"s3://crabby-images/aa8b5/aa8b563670b4acc1ba9d1c7a94ef9bd4e1a5c23e" alt=""
p + gghighlight(cyl == 6)
data:image/s3,"s3://crabby-images/26220/2622009dd89804d11c4f9fb1ce404ead16f15112" alt=""
p + gghighlight(cyl == 6, keep_scales = TRUE) +
ggtitle("keep_scales = TRUE")
data:image/s3,"s3://crabby-images/f29a8/f29a8feccff04be4531c3980cdf8d11566ced186" alt=""
d2 <- dplyr::sample_n(d, 20)
ggplot(d2, aes(idx, value)) +
geom_point() +
gghighlight(value > 0, label_key = type)
data:image/s3,"s3://crabby-images/3c23f/3c23f7a8a5d7581a4da56af4dfe738f416097f06" alt=""
d <- data.frame(
idx = c(1, 2, 3, 4, 1, 2, 3, 4),
value = c(10, 11, 12, 13, 4, 8, 16, 32),
cat1 = rep(c("a", "b"), each = 4),
cat2 = rep(rep(c("1-2", "3-4"), each = 2), 2),
stringsAsFactors = FALSE
)
p <- ggplot(d, aes(idx, value, colour = cat1)) +
geom_line() +
facet_wrap(vars(cat2))
p
data:image/s3,"s3://crabby-images/963de/963de2a72e92db7b593999c12d64d7aa89832881" alt=""
p + gghighlight(max(value) > 10)
data:image/s3,"s3://crabby-images/72fb7/72fb7764b174c60f9f448f952c5f7a2cd0bf4d41" alt=""
p +
gghighlight(max(value) > 10, calculate_per_facet = TRUE) +
ggtitle("calculate_per_facet = TRUE")
data:image/s3,"s3://crabby-images/2413f/2413f1d78be2edb79a890d2dba7899607da56337" alt=""
p <- ggplot(iris, aes(Sepal.Length, fill = Species)) +
geom_bar()+
gghighlight()
p
data:image/s3,"s3://crabby-images/32051/320515b0447b9480434c2f62a104aafb92bcfb59" alt=""
p + facet_wrap(~ Species)
data:image/s3,"s3://crabby-images/238ca/238caaec27bef2261c72d07c906834db2d9bf0ad" alt=""
set.seed(10)
d2 <- dplyr::sample_n(d, 20)
ggplot(d2, aes(idx, value)) +
geom_point() +
gghighlight(value > 0, label_key = type)