软件简介
Hadley Wickham编写的ggplot2是出色且灵活的作图软件包,可用于R中的优雅数据可视化。ggplot2默认生成的绘图需要进行一些格式化,才能作出发表级别的图片质量。另外,要自定义使用ggplot,但其语法是不透明的,这对没有熟练R编程技能的用户增加了难度。“ ggpubr”软件包提供了一些易于使用的功能,用于创建和自定义基于“ ggplot2”的图片绘制。
ggpubr包的主要特点:
- ggplot2软件包周围的包装,对于R编程的初学者来说,语法不太透明。
- 使用非高级R编程技能帮助研究人员轻松创建可随时发布的图。
- 可以将p值和显着性水平自动添加到箱形图,条形图,折线图等中。
- 使在同一页面上排列和注释多个图变得容易。
- 使更改颜色和标签等图形参数变得容易。
软件安装
软件安装很方便,安装完成直接加载调用
install.packages("ggpubr")
#或者
if(!require(devtools)) install.packages("devtools")
devtools::install_github("kassambara/ggpubr")
library(ggpubr)
密度分布图
set.seed(1234)
df <- data.frame(sex=factor(rep(c("F","M"),each=200)),weight=c(rnorm(200,55),rnorm(200,58)))
ggdensity(df,x="weight",add = "mean",rug = TRUE,color = "sex",fill = "sex",palette= c("#00AFBB", "#E7B800"))
data:image/s3,"s3://crabby-images/d5785/d57855101e70b75adf05d1bdd9513b7aa61c3cde" alt=""
柱状图
gghistogram(df,x="weight",add = "mean",rug = TRUE,color = "sex",fill = "sex",palette = c("#00AFBB", "#E7B800"))
data:image/s3,"s3://crabby-images/b4af6/b4af6f6dd5f3042c8e0e3eff6d45cbf297ed3588" alt=""
# Create some data format
set.seed(1234)
wdata = data.frame(sex = factor(rep(c("F", "M"), each=200)),weight = c(rnorm(200, 55), rnorm(200, 58)))
p1 <- ggqqplot(wdata, x = "weight")
p1
data:image/s3,"s3://crabby-images/31d3e/31d3e6bc4cf432576244e1773c41e963aa7fe988" alt=""
# Change colors and shape by groups ("sex")
# Use custom palette
p2 <- ggqqplot(wdata, x = "weight",
color = "sex", palette = c("#00AFBB", "#E7B800"))
p2
data:image/s3,"s3://crabby-images/577b2/577b283746ca0ad108cdf08d5633acad4a98f29f" alt=""
# Create some data format
set.seed(1234)
wdata = data.frame(
sex = factor(rep(c("F", "M"), each=200)),
weight = c(rnorm(200, 55), rnorm(200, 58)))
p1 <- ggecdf(wdata, x = "weight")
p1
data:image/s3,"s3://crabby-images/b93de/b93de9edff53251c60fae2ff03fc699886be24e6" alt=""
# Change colors and linetype by groups ("sex")
# Use custom palette
p2 <- ggecdf(wdata, x = "weight",
color = "sex", linetype = "sex",
palette = c("#00AFBB", "#E7B800"))
p2
data:image/s3,"s3://crabby-images/98f4e/98f4e76352d8de518c0bcc9a1dc00e3ed3886c1a" alt=""
p3 <- ggecdf(wdata, x = "weight", facet.by = "sex",
color = "sex", linetype = "sex",
palette = c("#00AFBB", "#E7B800"))
p3
data:image/s3,"s3://crabby-images/6b642/6b64222d81ec964a46f58262338bb02392c2fa6f" alt=""
箱线图小提琴图
rm(list = ls())
data("ToothGrowth")
df1<- ToothGrowth
head(df1)
p<- ggboxplot(df1,x="dose",y="len",color = "dose",palette=c("#00AFBB", "#E7B800", "#FC4E07"),add = "jitter",shape="dose")
p
my_comparisons <- list(c("0.5", "1"), c("1", "2"), c("0.5", "2"))
p + stat_compare_means(comparisons = my_comparisons)+ stat_compare_means(label.y = 50)
ggviolin(df1,x="dose",y="len",fill = "dose",palette = c("#00AFBB", "#E7B800", "#FC4E07"), add="boxplot", add.params=list(fill="white")) + stat_compare_means(comparisons = my_comparisons, label = "p.signif") + stat_compare_means(label.y = 50)
data:image/s3,"s3://crabby-images/4a486/4a486382cbbdcfeffcf1ca54d29f69f3d5de0716" alt=""
data:image/s3,"s3://crabby-images/8957a/8957ac7454caa6e915967ef5a36a6863de1b8231" alt=""
data:image/s3,"s3://crabby-images/65715/6571536589cb9ff3c65237fcdb600fcdcc2f2920" alt=""
柱状图
data("mtcars")
df2<- mtcars
df2$cyl <- factor(df2$cyl)
df2$name <- rownames(df2)
head(df2[,c("name","wt","mpg")])
ggbarplot(df2,x="name",y="mpg",fill = "cyl",color = "white",palette="npg",sort.val = "desc",sort.by.groups = FALSE,x.text.angle= 60)
data:image/s3,"s3://crabby-images/3a9c7/3a9c7b7c0d132d4046208d073bb99f7ac04e2256" alt=""
data("mtcars")
df2<- mtcars
df2$cyl <- factor(df2$cyl)
df2$name <- rownames(df2)
head(df2[,c("name","wt","mpg")])
ggbarplot(df2,x="name",y="mpg",fill = "cyl",color = "white",palette="aaas",sort.val = "asc",sort.by.groups = TRUE,x.text.angle= 60)
data:image/s3,"s3://crabby-images/4b877/4b877c3e0e5f8fe5af35f9ab78f33aac7d8ae246" alt=""
df2$mpg_z <- (df2$mpg - mean(df2$mpg))/sd(df2$mpg)
df2$mpg_grp <- factor(ifelse(df2$mpg_z<0,"low","high"),levels = c("low","high"))
head(df2[,c("name","wt","mpg","mpg_grp","cyl")])
ggbarplot(df2,x="name",y="mpg_z",fill = "mpg_grp",color = "white",palette="jco",sort.val = "asc",sort.by.groups = FALSE,x.text.angle=60,ylab="MPG z-score",xlab = FALSE,legend.title="MPG Group", rotate=TRUE)
data:image/s3,"s3://crabby-images/f12dd/f12dd2833c99616f2d177662035be84a8a92788b" alt=""
ggdotchart(df2,x="name",y="mpg",color="cyl",palette=c("#00AFBB", "#E7B800", "#FC4E07"),sorting = "ascending",label=round(df2$mpg),sort.by.groups=TRUE, add = "segments",ggtheme = theme_pubr())
data:image/s3,"s3://crabby-images/c15c6/c15c63121104516d8520279723916c2422c70d98" alt=""
散点图
data("mtcars")
df <- mtcars
df$cyl <- as.factor(df$cyl)
head(df)
p1 <- ggscatter(df, x = "wt", y = "mpg",
color = "red")
p1
data:image/s3,"s3://crabby-images/c2b6a/c2b6a4779b530b37de5f9e9950550f7094191079" alt=""
p2 <- ggscatter(df, x = "wt", y = "mpg",
color = "black", shape = 21, size = 3, # Points color, shape and size
add = "reg.line", # Add regressin line
add.params = list(color = "blue", fill = "lightgray"), # Customize reg. line
conf.int = TRUE, # Add confidence interval
cor.coef = TRUE, # Add correlation coefficient. see ?stat_cor
cor.coeff.args = list(method = "pearson", label.x = 3, label.sep = "\n")
)
p2
data:image/s3,"s3://crabby-images/34ad3/34ad37c528ad8869424db89cf5ac35bf629af478" alt=""
# loess method: local regression fitting
p3 <- ggscatter(df, x = "wt", y = "mpg",
add = "loess", conf.int = TRUE,
cor.coef = TRUE, # Add correlation coefficient. see ?stat_cor
cor.coeff.args = list(method = "spearman", label.x = 3, label.sep = "\n")
)
p3
data:image/s3,"s3://crabby-images/fb055/fb05514f4699e5e31687cd1dd34cbe04d851e58e" alt=""
# Control point size by continuous variable values ("qsec")
p4 <- ggscatter(df, x = "wt", y = "mpg",
color = "#00AFBB", size = "qsec")
p4
data:image/s3,"s3://crabby-images/46557/46557054f7845d2e90dc86e9247fee10c2c1998b" alt=""
# Change colors
# Use custom color palette
# Add marginal rug
p5 <- ggscatter(df, x = "wt", y = "mpg", color = "cyl", size = "qsec",
palette = c("#00AFBB", "#E7B800", "#FC4E07") )
p5
data:image/s3,"s3://crabby-images/d91e3/d91e340929a16cbf279acf639f6bb1a67dfe21c9" alt=""
p6 <- ggscatter(df, x = "wt", y = "mpg", color = "cyl", rug=TRUE,
palette = c("#00AFBB", "#E7B800", "#FC4E07") )
p6
data:image/s3,"s3://crabby-images/c56c9/c56c98c67bf639b0b4d07bea760583a6d00a5c14" alt=""
# Add group ellipses and mean points
# Add stars
p7 <- ggscatter(df, x = "wt", y = "mpg",
color = "cyl", shape = "cyl",
palette = c("#00AFBB", "#E7B800", "#FC4E07"),
ellipse = TRUE)
p7
data:image/s3,"s3://crabby-images/32cb8/32cb85710ee15f494556c9a37cdf22806bd568de" alt=""
p8 <- ggscatter(df, x = "wt", y = "mpg",
color = "cyl", shape = "cyl",
palette = c("#00AFBB", "#E7B800", "#FC4E07"),
ellipse = TRUE, ellipse.type = "convex",
mean.point = TRUE,
)
p8
data:image/s3,"s3://crabby-images/a1e4c/a1e4cf2755012449f910b44a8d8666e3dd74ecd5" alt=""
p9 <- ggscatter(df, x = "wt", y = "mpg",
color = "cyl", shape = "cyl",
palette = c("#00AFBB", "#E7B800", "#FC4E07"),
ellipse = TRUE, ellipse.type = 'confidence',
mean.point = TRUE,
star.plot = TRUE)
p9
data:image/s3,"s3://crabby-images/ee47a/ee47a15e6534064c31e6ddd303b8c629154dccdf" alt=""
# Textual annotation
df$name <- rownames(df)
p10 <- ggscatter(df, x = "wt", y = "mpg",
color = "cyl", palette = c("#00AFBB", "#E7B800", "#FC4E07"),
label = "name")
p10
data:image/s3,"s3://crabby-images/29ef2/29ef2ea4124b5b644db6c63a1a3224aef11cc3da" alt=""
p11 <- ggscatter(df, x = "wt", y = "mpg",
color = "cyl", palette = c("#00AFBB", "#E7B800", "#FC4E07"),
label = "name", repel = TRUE)
p11
data:image/s3,"s3://crabby-images/f399d/f399d9d5d6252d0e8b8d5fbb5b2c393ce1445403" alt=""
# Data
df <- data.frame(dose=c("D0.5", "D1", "D2"),
len=c(4.2, 10, 29.5))
print(df)
p1 <- ggbarplot(df,x="dose",y="len",label=TRUE,label.pos="out")
p1
data:image/s3,"s3://crabby-images/44880/448805ba5c1b5bd52087843c681fb7852c4129ad" alt=""
# Change width 更改柱子的宽度
p2 <- ggbarplot(df, x = "dose", y = "len", width = 0.2)
p2
data:image/s3,"s3://crabby-images/a80b8/a80b8b667ae2cfa8b030b80895fe06c7366f49c9" alt=""
# Change the plot orientation: horizontal 变换坐标轴的方向
p3 <- ggbarplot(df, "dose", "len", orientation = "horiz")
p3
data:image/s3,"s3://crabby-images/4c6ff/4c6ff3106e81ad41e6d3497c2071ace1e5145a1e" alt=""
# Change the default order of items 设定指定的排列顺序
p4 <- ggbarplot(df, "dose", "len",
order = c("D2", "D1", "D0.5"))
p4
data:image/s3,"s3://crabby-images/433bf/433bf899826480f762f92689d2f5877aaed64ff9" alt=""
# Change colors 更改填充色和边框色
# Change fill and outline color
# add labels inside bars
p5 <- ggbarplot(df, "dose", "len",
fill = "steelblue", color = "black",
label = TRUE, lab.pos = "in", lab.col = "white")
p5
data:image/s3,"s3://crabby-images/4ebf6/4ebf6cf1b0ffd2528a6de75f90b9979692b637aa" alt=""
# Change colors by groups: dose
# Use custom color palette
p6 <- ggbarplot(df, "dose", "len", color = "dose",
palette = c("#00AFBB", "#E7B800", "#FC4E07"))
p6
data:image/s3,"s3://crabby-images/5eda9/5eda9b07eecfbbb9a9e8965a627bcb620d7c662c" alt=""
# Change fill and outline colors by groups
p7 <- ggbarplot(df, "dose", "len",
fill = "dose", color = "dose",
palette = c("#00AFBB", "#E7B800", "#FC4E07"))
p7
data:image/s3,"s3://crabby-images/3ff7c/3ff7c3500be2f0a0342fba48e067d776bf95ac3d" alt=""
# Plot with multiple groups 分组绘图
# Create some data
df2 <- data.frame(supp=rep(c("VC", "OJ"), each=3),
dose=rep(c("D0.5", "D1", "D2"),2),
len=c(6.8, 15, 33, 4.2, 10, 29.5))
print(df2)
# Plot "len" by "dose" and change color by a second group: "supp"
# Add labels inside bars
p8 <- ggbarplot(df2, "dose", "len",
fill = "supp", color = "supp",
label = TRUE, lab.col = "white", lab.pos = "in")
p8
data:image/s3,"s3://crabby-images/21ad2/21ad239f326eac0bf895ba50c1f7d92d4f2e186b" alt=""
# Change position: Interleaved (dodged) bar plot 更改排列方式
p9 <- ggbarplot(df2, "dose", "len",
fill = "supp", color = "supp", palette = "Paired",
label = TRUE,
position = position_dodge())
p9
data:image/s3,"s3://crabby-images/e37cc/e37cce9b0f9e64f7adb223c3ce5f7ea6b258b5ea" alt=""
p10 <- ggbarplot(df2, "dose", "len",
fill = "supp", color = "supp", palette = "Paired",
label = TRUE,
position = position_fill())
p10
data:image/s3,"s3://crabby-images/7ae20/7ae20df7b78e1d064be7bc549f1a7f0bfcbc0317" alt=""
# Add points and errors
# Data: ToothGrowth data set we'll be used.
df3 <- ToothGrowth
head(df3, 10)
# It can be seen that for each group we have
# different values
p11 <- ggbarplot(df3, x = "dose", y = "len",width =0.3)
p11
data:image/s3,"s3://crabby-images/cfffe/cfffeb7cfe922c4bd67d67f834e799b05c4d6c75" alt=""
# Visualize the mean of each group
p12 <- ggbarplot(df3, x = "dose", y = "len",
add = "mean")
p12
data:image/s3,"s3://crabby-images/ad1c2/ad1c2e8731c20ba104abcb552c48eebf7b37a29f" alt=""
# Add error bars: mean_se 添加不同类型的误差棒
# (other values include: mean_sd, mean_ci, median_iqr, ....)
# Add labels
p13 <- ggbarplot(df3, x = "dose", y = "len",
add = "mean_se", label = TRUE, lab.vjust = -1.6)
p13
data:image/s3,"s3://crabby-images/ea200/ea20057f641c78b029a67839712b0d915b2e313c" alt=""
# Use only "upper_errorbar"
p14 <- ggbarplot(df3, x = "dose", y = "len",
add = "mean_se", error.plot = "upper_errorbar")
p14
data:image/s3,"s3://crabby-images/80dfa/80dfa7b18eeab98bcd58f87242f58fbab851e2e3" alt=""
# Change error.plot to "pointrange"
p15 <- ggbarplot(df3, x = "dose", y = "len",
add = "mean_se", error.plot = "pointrange")
p15
data:image/s3,"s3://crabby-images/03718/03718a0cab75cf91896b4f27462d8c8df0088538" alt=""
# Add jitter points and errors (mean_se)
p16 <- ggbarplot(df3, x = "dose", y = "len",
add = c("mean_se", "jitter"))
p16
data:image/s3,"s3://crabby-images/f0bfa/f0bfa7a00e3dbef07c49cea78c2cb79063d27048" alt=""
# Add dot and errors (mean_se)
p17 <- ggbarplot(df3, x = "dose", y = "len",
add = c("mean_se", "dotplot"))
p17
data:image/s3,"s3://crabby-images/09daa/09daacc1084b65ccedded9756f3a3ff41ff23189" alt=""
# Multiple groups with error bars and jitter point
p18 <- ggbarplot(df3, x = "dose", y = "len", color = "supp",
add = "mean_se", palette = c("#00AFBB", "#E7B800"),
position = position_dodge())
p18
data:image/s3,"s3://crabby-images/750fa/750fa6b6f53dfbe936d741bbc9ded3cf12382e6b" alt=""
MA图
# 加载数据集
data(diff_express)
head(diff_express)
p1 <- ggmaplot(diff_express, fdr = 0.05, fc = 2, size = 0.4,
palette = c("red","green","gray"))
p1
data:image/s3,"s3://crabby-images/2c939/2c939d8a11fec4248cd0e67f52ef7a3506ca79e8" alt=""
p2 <- ggmaplot(diff_express, main = expression("Group 1" %->% "Group 2"),
fdr = 0.05, fc = 2, size = 0.4,
palette = c("#B31B21", "#1465AC", "darkgray"),
genenames = as.vector(diff_express$name),
xlab = "M",ylab = "A",
legend = "top", top = 20,
font.label = c("bold", 11),
font.legend = "bold",
font.main = "bold",
ggtheme = ggplot2::theme_minimal())
p2
data:image/s3,"s3://crabby-images/202f0/202f00fbe4d724816da1e693df6ef406a53e144c" alt=""
# Add rectangle around labels
p3 <- ggmaplot(diff_express, main = expression("Group 1" %->% "Group 2"),
fdr = 0.05, fc = 2, size = 0.4,
palette = c("#B31B21", "#1465AC", "darkgray"),
genenames = as.vector(diff_express$name),
legend = "top", top = 20,
font.label = c("bold", 11), label.rectangle = TRUE,
font.legend = "bold", select.top.method = "padj",
font.main = "bold",
ggtheme = ggplot2::theme_minimal())
p3
data:image/s3,"s3://crabby-images/f1885/f18856a1e7467385982c8d02a906ec50428055ba" alt=""
p4 <- ggmaplot(diff_express, main = expression("Group 1" %->% "Group 2"),
fdr = 0.05, fc = 2, size = 0.5,
palette = c("#B31B21", "#1465AC", "darkgray"),
genenames = as.vector(diff_express$name),
legend = "top", top = 20, select.top.method = "fc",
font.label = c("bold", 11), label.rectangle = TRUE,
font.legend = "bold",
font.main = "bold",
ggtheme = ggplot2::theme_minimal())
p4
data:image/s3,"s3://crabby-images/074f9/074f9ecaaa65f53b31face5e18c9783729c3da87" alt=""
饼状图
# Data: Create some data
df <- data.frame(
group = c("Male", "Female", "Child"),
value = c(25, 25, 50))
head(df)
p1 <- ggpie(df, "value", label = "group")
p1
data:image/s3,"s3://crabby-images/b4a65/b4a65542f083abb6054f97a2dd6ed4cab451d2bc" alt=""
# Change color
# Change fill color by group
# set line color to white
# Use custom color palette
p2 <- ggpie(df, "value", label = "group",
fill = "group", color = "white",
palette = c("#00AFBB", "#E7B800", "#FC4E07") )
p2
data:image/s3,"s3://crabby-images/239f9/239f9def454dc7cd3ba205268cbf482ecad4b326" alt=""
# Change label
# Show group names and value as labels
labs <- paste0(df$group, " (", df$value, "%)")
labs
p3 <- ggpie(df, "value", label = labs,
fill = "group", color = "white",
palette = c("#00AFBB", "#E7B800", "#FC4E07"))
p3
data:image/s3,"s3://crabby-images/72b9a/72b9af4f88be749b98122debbdeb1e690bfba841" alt=""
# Change the position and font color of labels
p4 <- ggpie(df, "value", label = labs,
lab.pos = "in", lab.font = "white",
fill = "group", color = "white",
palette = c("#00AFBB", "#E7B800", "#FC4E07"))
p4
data:image/s3,"s3://crabby-images/b1d07/b1d07660f24051a90d4d8dbdbf8c4aa9abb3c521" alt=""
网友评论