ggpubr001 安装及使用

原文链接:ggpubr: ‘ggplot2’ Based Publication Ready Plots

1.ggpubr

Hadley Wickham编写的ggplot2是出色且灵活的软件包,可用于R中的优雅数据可视化。但是,默认生成的绘图必须先进行一些格式化,然后才能发送它们进行发布。 此外,要自定义ggplot,语法是不透明的,这对没有高级R编程技能的研究人员增加了难度。

“ ggpubr”软件包提供了一些易于使用的功能,用于创建和自定义基于“ ggplot2”的可发布出版物的图表。

https://rpkgs.datanovia.com/ggpubr上可找到更多信息。

幕布链接:https://share.mubu.com/doc/6kFLvwuA6he

ggpubr

2.ggpubr安装及加载

2.1 从CRAN安装
install.packages("ggplot2")
install.packages("ggpubr")
2.2 从Github安装最新版
# Install
if(!require(devtools)) install.packages("devtools")
devtools::install_github("kassambara/ggpubr")

3.分布图 Distribution

library(ggpubr)
#>加载所需的包: ggplot2
#>加载所需的包: magrittr
# 创建数据集
set.seed(1234)
wdata = data.frame(
   sex = factor(rep(c("F", "M"), each=200)),
   weight = c(rnorm(200, 55), rnorm(200, 58)))
# head(dataframe),默认查看数据集前6行数据
head(wdata, 4)
# 带有平均线和边际地毯的密度图
# 按组更改轮廓和填充颜色(“性别”)
# 使用自定义调色板
ggdensity(wdata, x = "weight",
   add = "mean", rug = TRUE,
   color = "sex", fill = "sex",
   palette = c("#00AFBB", "#E7B800"))
带有平均线和边际地毯的密度图
#带有平均线和边缘地毯的直方图
#按组更改轮廓和填充颜色(“性别”)
#使用自定义调色板
gghistogram(wdata, x = "weight",
            add = "mean", rug = TRUE,
            color = "sex", fill = "sex",
            palette = c("#00AFBB", "#E7B800"))
带有平均线和边缘地毯的直方图

4.箱形图和小提琴图 Box plots and violin plots

# 加载数据
data("ToothGrowth")
df <- ToothGrowth
# head(dataframe),默认查看数据集前6行数据
head(df, 4)
#带有抖动点的箱形图
#按组更改轮廓颜色:剂量
#使用自定义调色板
#添加抖动点并按组更改形状
 p <- ggboxplot(df, x = "dose", y = "len",
                color = "dose", palette =c("#00AFBB", "#E7B800", "#FC4E07"),
                add = "jitter", shape = "dose")
 p
带有抖动点的箱形图
# 添加p值比较组
# 指定所需的比较
my_comparisons <- list( c("0.5", "1"), c("1", "2"), c("0.5", "2") )
p + stat_compare_means(comparisons = my_comparisons)+ 
#添加成对比较p值
stat_compare_means(label.y = 50)                   
# 添加全局p值
image.png
# 内嵌箱线图的小提琴图
# 按组更改填充颜色:剂量
# 添加带有白色填充颜色的箱线图
ggviolin(df, 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)                                      
# 添加全局p值
内嵌箱线图的小提琴图

5.条形图 Bar plots

  • Demo data set
# 加载数据
data("mtcars")
dfm <- mtcars
# 将cyl变量转换为因子
dfm$cyl <- as.factor(dfm$cyl)
# 添加组名
dfm$name <- rownames(dfm)
# 检查数据
head(dfm[, c("name", "wt", "mpg", "cyl")])
  • Ordered bar plots
    通过分组变量“ cyl”更改填充颜色。 排序将在全局范围内进行,但不会按组进行。
ggbarplot(dfm, x = "name", y = "mpg",
          fill = "cyl",               # 通过cyl更改填充颜色
          color = "white",            # 将条形边框颜色设置为白色
          palette = "jco",            # jco journal color palett. see ?ggpar
          sort.val = "desc",          # 以升序对值进行排序
          sort.by.groups = FALSE,     # 不要在每个组内排序
          x.text.angle = 90           # 垂直旋转x轴文本
          )
image.png
ggbarplot(dfm, x = "name", y = "mpg",
          fill = "cyl",               # 通过cyl更改填充颜色
          color = "white",            # 将条形边框颜色设置为白色
          palette = "jco",            # jco journal color palett. see ?ggpar
          sort.val = "asc",           # 按降序对值排序
          sort.by.groups = TRUE,      # 在每个组内排序
          x.text.angle = 90           # 垂直旋转x轴文本
image.png

6.偏差图 Deviation graphs

偏差图显示定量值与参考值的偏差。 在下面的R代码中,我们将绘制mtcars数据集中的mpg z得分。
计算mpg数据的z得分:

# 计算mpg的z-score 
dfm$mpg_z <- (dfm$mpg -mean(dfm$mpg))/sd(dfm$mpg)
dfm$mpg_grp <- factor(ifelse(dfm$mpg_z < 0, "low", "high"),
                     levels = c("low", "high"))
# 检查数据
head(dfm[, c("name", "wt", "mpg", "mpg_z", "mpg_grp", "cyl")])
# 创建一个有序的条形图,根据mpg的级别进行着色:
ggbarplot(dfm, x = "name", y = "mpg_z",
          fill = "mpg_grp",           # 通过mpg_level更改填充颜色 
          color = "white",            # 将条形边框颜色设置为白色
          palette = "jco",            # jco journal color palett. see ?ggpar
          sort.val = "asc",           # 按降序对值排序
          sort.by.groups = FALSE,     # 不要在每个组内排序
          x.text.angle = 90,          # 垂直旋转x轴文本
          ylab = "MPG z-score",
          xlab = FALSE,
          legend.title = "MPG Group"
image.png

旋转绘图:使用rotate = TRUE和sort.val =“ desc”

ggbarplot(dfm, x = "name", y = "mpg_z",
          fill = "mpg_grp",           # 通过mpg_level更改填充颜色 
          color = "white",            # 将条形边框颜色设置为白色
          palette = "jco",            # jco journal color palett. see ?ggpar
          sort.val = "asc",           # 按降序对值排序
          sort.by.groups = FALSE,     # 不要在每个组内排序
          x.text.angle = 90,          # 垂直旋转x轴文本
          ylab = "MPG z-score",
          legend.title = "MPG Group",
          rotate = TRUE,
          ggtheme = theme_minimal()
image.png

7.点图 Dot charts

  • 棒棒糖图
    当您具有大量要可视化的值时,棒棒糖图表可以代替条形图。
    棒棒糖图表由分组变量“ cyl”着色
ggdotchart(dfm, x = "name", y = "mpg",
           color = "cyl",                                # 按组区分颜色
           palette = c("#00AFBB", "#E7B800", "#FC4E07"), # 自定义调色板
           sorting = "ascending",                        # 按降序对值进行排序
           add = "segments",                             # 将y = 0的段添加到点
           ggtheme = theme_pubr()                        # 选择ggplot2主题
棒棒糖图
ggdotchart(dfm, x = "name", y = "mpg",
           color = "cyl",                                # 按组区分颜色
           palette = c("#00AFBB", "#E7B800", "#FC4E07"), # 自定义调色板
           sorting = "descending",                       # 按降序对值进行排
           add = "segments",                             # 将y = 0的段添加到点
           rotate = TRUE,                                # 垂直旋转图
           group = "cyl",                                # 按cyl进行分组
           dot.size = 6,                                 # 设置dot点大小
           label = round(dfm$mpg),                        # 添加mpg值标签
           font.label = list(color = "white", size = 9,
                             vjust = 0.5),               # 调整标签参数
           ggtheme = theme_pubr()                        # ggplot2 theme
)
image.png

ggdotchart(dfm, x = "name", y = "mpg_z",
           color = "cyl",                                # 按组区分颜色
           palette = c("#00AFBB", "#E7B800", "#FC4E07"), # 自定义调色板
           sorting = "descending",                       # 按降序对值进行排序
           add = "segments",                             # 将y = 0的段添加到点
           add.params = list(color = "lightgray", size = 2), # 更改元素的颜色和大小
           group = "cyl",                                # 按cyl进行分组
           dot.size = 6,                                 # 设置dot点大小
           label = round(dfm$mpg_z,1),                        # 添加mpg值标签
           font.label = list(color = "white", size = 9,
                             vjust = 0.5),               # 调整标签参数
           ggtheme = theme_pubr()                        # ggplot2 theme
)+
# 添加水平线
  geom_hline(yintercept = 0, linetype = 2, color = "lightgray")
image.png
ggdotchart(dfm, x = "name", y = "mpg",
           color = "cyl",                                # 按组区分颜色
           palette = c("#00AFBB", "#E7B800", "#FC4E07"), # 自定义调色板
           sorting = "descending",                       # 按降序对值进行排序
           rotate = TRUE,                                # 旋转绘图
           dot.size = 2,                                 # 设置dot点大小
           y.text.col = TRUE,                            # 按组上色y轴标签
           ggtheme = theme_pubr()                        # ggplot2 theme
)+
  theme_cleveland()                                      # 添加虚线网格
克里夫兰圆点图 Cleveland’s dot plot

More

Find out more at https://rpkgs.datanovia.com/ggpubr.

Blog posts

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
禁止转载,如需转载请通过简信或评论联系作者。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,905评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,140评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,791评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,483评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,476评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,516评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,905评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,560评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,778评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,557评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,635评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,338评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,925评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,898评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,142评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,818评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,347评论 2 342

推荐阅读更多精彩内容