R語(yǔ)言可視化學(xué)習(xí)筆記之ggpubr包

Hadley Wickham創(chuàng)建的可視化包ggplot2可以流暢地進(jìn)行優(yōu)美的可視化戴而,但是如果要通過(guò)ggplot2定制一套圖形换途,尤其是適用于雜志期刊等出版物的圖形,對(duì)于那些沒(méi)有深入了解ggplot2的人來(lái)說(shuō)就有點(diǎn)困難了毅访,ggplot2的部分語(yǔ)法是很晦澀的竟痰。為此Alboukadel Kassambara創(chuàng)建了基于ggplot2的可視化包ggpubr用于繪制符合出版物要求的圖形。

安裝及加載ggpubr

安裝方式有兩種:

  • 直接從CRAN安裝:
install.packages("ggpubr")
  • GitHub上安裝最新版本:
if(!require(devtools)) install.packages("devtools")
 devtools::install_github("kassambara/ggpubr")

安裝完之后直接加載就行:

library(ggpubr)

ggpubr可繪制圖形:

ggpubr可繪制大部分我們常用的圖形硬霍,下面一一介紹帜慢。

分布圖(Distribution)

#構(gòu)建數(shù)據(jù)集
set.seed(1234)
df <- data.frame( sex=factor(rep(c("f", "M"), each=200)), 
weight=c(rnorm(200, 55), rnorm(200, 58)))
head(df)
##   sex   weight
## 1  f   53.79293
## 2  f   55.27743
## 3  f   56.08444
## 4  f   52.65430
## 5  f   55.42912
## 6  f   55.50606

密度分布圖以及邊際地毯線并添加平均值線

ggdensity(df, x="weight", add = "mean", rug = TRUE, color = "sex", fill = "sex",
palette = c("#00AFBB", "#E7B800"))

帶有均值線和邊際地毯線的直方圖

gghistogram(df, x="weight", add = "mean", rug = TRUE, color = "sex", fill = "sex",
palette = c("#00AFBB", "#E7B800"))

箱線圖與小提琴圖

#加載數(shù)據(jù)集ToothGrowth
data("ToothGrowth")
df1 <- ToothGrowth
head(df1)
##    len  supp  dose
## 1  4.2   VC    0.5
## 2  11.5  VC    0.5
## 3  7.3   VC    0.5
## 4  5.8   VC    0.5
## 5  6.4   VC    0.5
## 6  10.0  VC    0.5
p <- ggboxplot(df1, x="dose", y="len", color = "dose", 
palette = c("#00AFBB", "#E7B800", "#FC4E07"), 
add = "jitter", shape="dose")#增加了jitter點(diǎn),點(diǎn)shape由dose映射p

增加不同組間的p-value值唯卖,可以自定義需要標(biāo)注的組間比較

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)

內(nèi)有箱線圖的小提琴圖

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")+#label這里表示選擇顯著性標(biāo)記(星號(hào)) 
stat_compare_means(label.y = 50)

條形圖

data("mtcars")
df2 <- mtcars
df2$cyl <- factor(df2$cyl)
df2$name <- rownames(df2)#添加一行name
head(df2[, c("name", "wt", "mpg", "cyl")])

按從小到大順序繪制條形圖(不分組排序)

ggbarplot(df2, x="name", y="mpg", fill = "cyl", color = "white", 
palette = "jco",#雜志jco的配色 
sort.val = "desc",#下降排序 
sort.by.groups=FALSE,#不按組排序 
x.text.angle=60)

按組進(jìn)行排序

ggbarplot(df2, x="name", y="mpg", fill = "cyl", color = "white", 
palette = "jco",#雜志jco的配色 
sort.val = "asc",#上升排序,區(qū)別于desc粱玲,具體看圖演示 
sort.by.groups=TRUE,#按組排序 
x.text.angle=90)

偏差圖

偏差圖展示了與參考值之間的偏差

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")])

繪制排序過(guò)的條形圖

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")

坐標(biāo)軸變換

ggbarplot(df2, x="name", y="mpg_z", fill = "mpg_grp", color = "white", 
palette = "jco", sort.val = "desc", sort.by.groups = FALSE, 
x.text.angle=90, ylab = "MPG z-score", xlab = FALSE, 
legend.title="MPG Group", rotate=TRUE, ggtheme = theme_minimal())

點(diǎn)圖(Dot charts)

棒棒糖圖(Lollipop chart)

棒棒圖可以代替條形圖展示數(shù)據(jù)

ggdotchart(df2, x="name", y="mpg", color = "cyl", 
palette = c("#00AFBB", "#E7B800", "#FC4E07"), sorting = "ascending", 
add = "segments", ggtheme = theme_pubr())

可以自設(shè)置各種參數(shù)

ggdotchart(df2, x="name", y="mpg", color = "cyl", 
palette = c("#00AFBB", "#E7B800", "#FC4E07"), sorting = "descending", 
add = "segments", rotate = TRUE, group = "cyl", dot.size = 6, 
label = round(df2$mpg), font.label = list(color="white", size=9, vjust=0.5), 
ggtheme = theme_pubr())

偏差圖

ggdotchart(df2, x="name", y="mpg_z", color = "cyl", 
palette = c("#00AFBB", "#E7B800", "#FC4E07"), sorting = "descending", 
add = "segment", add.params = list(color="lightgray", size=2), 
group = "cyl", dot.size = 6, label = round(df2$mpg_z, 1), 
font.label = list(color="white", size=9, vjust=0.5), ggtheme = theme_pubr())+ 
geom_line(yintercept=0, linetype=2, color="lightgray")

Cleveland點(diǎn)圖

ggdotchart(df2, x="name", y="mpg", color = "cyl", 
palette = c("#00AFBB", "#E7B800", "#FC4E07"), sorting = "descending", 
rotate = TRUE, dot.size = 2, y.text.col=TRUE, ggtheme = theme_pubr())+ 
theme_cleveland()

SessionInfo

sessionInfo()
## R version 3.4.0 (2017-04-21)
## Platform: x86_64-w64-mingw32/x64 (64-bit)
## Running under: Windows 8.1 x64 (build 9600)
## 
## Matrix products: default
## 
## locale:
## [1] LC_COLLATE=Chinese (Simplified)_China.936 
## [2] LC_CTYPE=Chinese (Simplified)_China.936 
## [3] LC_MONETARY=Chinese (Simplified)_China.936
## [4] LC_NUMERIC=C 
## [5] LC_TIME=Chinese (Simplified)_China.936 
## 
## attached base packages:
## [1] stats graphics grDevices utils datasets methods base 
## 
## other attached packages:
## [1] ggpubr_0.1.3 magrittr_1.5 ggplot2_2.2.1
## 
## loaded via a namespace (and not attached):
## [1] Rcpp_0.12.11 knitr_1.16 munsell_0.4.3 colorspace_1.3-2
## [5] R6_2.2.1 rlang_0.1.1 stringr_1.2.0 plyr_1.8.4 
## [9] dplyr_0.5.0 tools_3.4.0 grid_3.4.0 gtable_0.2.0 
## [13] DBI_0.6-1 htmltools_0.3.6 yaml_2.1.14 lazyeval_0.2.0 
## [17] rprojroot_1.2 digest_0.6.12 assertthat_0.2.0 tibble_1.3.3 
## [21] ggsignif_0.2.0 ggsci_2.4 purrr_0.2.2.2 evaluate_0.10 
## [25] rmarkdown_1.5 labeling_0.3 stringi_1.1.5 compiler_3.4.0 
## [29] scales_0.4.1 backports_1.1.0
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市拜轨,隨后出現(xiàn)的幾起案子抽减,更是在濱河造成了極大的恐慌,老刑警劉巖橄碾,帶你破解...
    沈念sama閱讀 217,185評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件卵沉,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡法牲,警方通過(guò)查閱死者的電腦和手機(jī)史汗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)拒垃,“玉大人淹办,你說(shuō)我怎么就攤上這事《窀矗” “怎么了怜森?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,524評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)谤牡。 經(jīng)常有香客問(wèn)我副硅,道長(zhǎng),這世上最難降的妖魔是什么翅萤? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,339評(píng)論 1 293
  • 正文 為了忘掉前任恐疲,我火速辦了婚禮,結(jié)果婚禮上套么,老公的妹妹穿的比我還像新娘培己。我一直安慰自己,他們只是感情好胚泌,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,387評(píng)論 6 391
  • 文/花漫 我一把揭開(kāi)白布省咨。 她就那樣靜靜地躺著,像睡著了一般玷室。 火紅的嫁衣襯著肌膚如雪零蓉。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,287評(píng)論 1 301
  • 那天穷缤,我揣著相機(jī)與錄音敌蜂,去河邊找鬼。 笑死津肛,一個(gè)胖子當(dāng)著我的面吹牛章喉,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播身坐,決...
    沈念sama閱讀 40,130評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼秸脱,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了掀亥?” 一聲冷哼從身側(cè)響起撞反,我...
    開(kāi)封第一講書(shū)人閱讀 38,985評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎搪花,沒(méi)想到半個(gè)月后遏片,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,420評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡撮竿,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,617評(píng)論 3 334
  • 正文 我和宋清朗相戀三年吮便,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片幢踏。...
    茶點(diǎn)故事閱讀 39,779評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡髓需,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出房蝉,到底是詐尸還是另有隱情僚匆,我是刑警寧澤微渠,帶...
    沈念sama閱讀 35,477評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站咧擂,受9級(jí)特大地震影響逞盆,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜松申,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,088評(píng)論 3 328
  • 文/蒙蒙 一云芦、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧贸桶,春花似錦舅逸、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,716評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至设联,卻和暖如春善已,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背离例。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,857評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工换团, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人宫蛆。 一個(gè)月前我還...
    沈念sama閱讀 47,876評(píng)論 2 370
  • 正文 我出身青樓艘包,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親耀盗。 傳聞我的和親對(duì)象是個(gè)殘疾皇子想虎,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,700評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容