使用ggplot绘制柱状图,在柱子中显示数值和显著性
[data:image/s3,"s3://crabby-images/3c9e3/3c9e3f82ce82203c4ca9dc1e3762b8e62ec8cf72" alt=""](http://mp.weixin.qq.com/s?__biz=MzAwODY5NDU0MA==&mid=2455861689&idx=2&sn=bf497c5f96fbccc071751f5e9eb087a5&chksm=8cff27dabb88aecc14142b2712e8bbd0f4ed2d6660b4814cd2031212edf682bd8c61f2fb391a&scene=21#wechat_redirect)**「一边学习,一边总结,一边分享!」**
**由于微信改版,一直有同学反映。存在长时间接收不到公众号的推文。那么请跟随以下步骤,将**「小杜的生信筆記」**设置为**「星标」,不错过每一条推文教程。
data:image/s3,"s3://crabby-images/ee99a/ee99a3d2b38cad15c036ef9f538980eafd76f591" alt=""
### 本期教程
data:image/s3,"s3://crabby-images/047f7/047f7cd84da0938efa22298942cf93ae556e60e5" alt=""
**获得本期教程示例数据,后台回复关键词:「20240628」。(PS:在社群中,可获得往期和未来教程所有数据和代码)**
### 往期教程部分内容
data:image/s3,"s3://crabby-images/6163e/6163e7b9e1cf8bbbe2cd0c3ff986361681437f47" alt=""data:image/s3,"s3://crabby-images/a55e2/a55e25a484590ef3c7ac84cd83ec57e2f24af84d" alt=""data:image/s3,"s3://crabby-images/1a96b/1a96bd16fadf3d306edf772ae1920b539ad2233f" alt=""data:image/s3,"s3://crabby-images/0706a/0706a27e94cfd828d82e95fa55c95cc9fd72d3a9" alt=""data:image/s3,"s3://crabby-images/ff6da/ff6da99d656b97a984017265da621dd4437aef6c" alt=""data:image/s3,"s3://crabby-images/49cc3/49cc300875cd26aef7f66a4e162fcbdd741c190b" alt=""data:image/s3,"s3://crabby-images/64c59/64c5989d92e48d6f10d4e540908a397d55a6f6d5" alt=""data:image/s3,"s3://crabby-images/ee55b/ee55b548d43931a9d7b9ea53d68503d7285a153d" alt=""data:image/s3,"s3://crabby-images/7c731/7c731a5ac40a2d338243e2b384b432670f7e3b1c" alt=""data:image/s3,"s3://crabby-images/c319e/c319ebbbb5e9d4c2e19f8b35804b39bc89009fa1" alt=""data:image/s3,"s3://crabby-images/cedff/cedff56dcc9f016b32160a8946b5d7a1411df591" alt=""data:image/s3,"s3://crabby-images/6ab7a/6ab7a4276af0e2c362ec86da24beba2cec75e4e6" alt=""data:image/s3,"s3://crabby-images/2c476/2c47606762f1ea459b1b603e6eab5729c62aa128" alt=""
## 写在前面
**基于ggplot绘制柱状图,小技巧,很基础的图形。但是,越到后面,会发现,越是基础的图形,我们使用的频率越高。今天的教程是基于发芽指数来绘制,我们模拟一个发芽数和天数,计算出发芽指数。**
### 代码
```plain
##'@在柱状图中显示数字
##'@2024.06.28
##'@
##'@小杜的生信笔记
library(ggplot2)
library(dplyr)
library(tidyr)
library(ggplot2)
library(agricolae)
setwd("D:\\BioinfoFile\\小杜的生信笔记\\2024\\20240628_柱状图中显示数据")
##'@此次数据基于种子发芽指数计算公式进行,数据具有随机性,不具有任何意义。
##'@加载数据
data <- read.csv("20240628_inputdata.csv",header = T)
data
```
data:image/s3,"s3://crabby-images/8c4a4/8c4a4d56a000d55d1209818295774e35263c712d" alt=""
**「相关计算代码」**
data:image/s3,"s3://crabby-images/7ed7f/7ed7f7a804ab584e251f4acaf412efbbcd8b0575" alt=""
```plain
## 转换数据
long_data <- data %>%
pivot_longer(cols = starts_with("germinated"), names_to = "replicate", values_to = "germinated")
long_data
##计算活力指数
germination_index <- long_data %>%
group_by(treatment, day) %>%
summarise(GI = sum(germinated / day)) %>%
ungroup()
#'@计算各个处理的平均数和标准差
summary_gi <- germination_index %>%
group_by(treatment) %>%
summarise(mean_GI = mean(GI), sd_GI = sd(GI))
#'@单因素方差分析
anova_result <- aov(GI ~ treatment + day, data = germination_index)
summary(anova_result)
#'@进行Tukey HSD检验
tukey_result <- HSD.test(anova_result, "treatment", group = TRUE)
print(tukey_result)
# 提取 Tukey HSD 结果中的字母标记
groups <- tukey_result$groups
df_letters <- data.frame(sample = rownames(groups), letters = groups$groups)
##'@修改名称
colnames(df_letters) <- c("treatment","letters")
# 合并均值和字母标记
df_data <- merge(summary_gi, df_letters, by = "treatment")
```
### 绘图
```plain
ggplot(df_data, aes(x = treatment, y = mean_GI, fill = treatment)) +
geom_bar(stat = "identity", position = "dodge", color = "black", size = 0.5) +
##'@误差线
geom_errorbar(aes(ymin = mean_GI - sd_GI, ymax = mean_GI + sd_GI), width = 0.15, ## 宽度
size = 1##字体大小
) +
##'@显示数字
geom_text(aes(x = treatment, y = mean_GI + sd_GI + 0.5,## “+0.5”显示的高度
label = round(mean_GI, 2)), ### "round(mean_GI, 2))",其中2,表示数字显示的小数点位数
size = 5,
color = 'black') +
##'@显示显著性
geom_text(aes(x = treatment, y = mean_GI + sd_GI + 1.3, label = letters), size = 6, color = "red") +
theme_bw()+
scale_fill_manual(values = c("#1f78b4", "#ff7f00", "#4daf4a")) +
labs(x = NULL, y = "Germination Index")+
theme(#axis.line = element_line(size = 1),## 粗细
text=element_text(#family = "sans",
colour ="black",size = 10),
axis.text.x = element_text(color = "black", size = 12),
axis.text.y = element_text(color = "black",size = 11),
axis.ticks = element_line(colour = "black"),
strip.text = element_text(color = "black",size = 10),
axis.title = element_text(color = "black",size = 12), ##坐标轴字体大小
legend.position = "none",
strip.background = element_blank()
)
ggsave("20240608_柱状图-显示数字.pdf",width = 6, height = 4)
```
data:image/s3,"s3://crabby-images/f37e5/f37e58f5440077f21006e4fa0a0ada70c16b4108" alt=""
**获得本期教程示例数据,后台回复关键词:「20240628」。(PS:在社群中,可获得往期和未来教程所有数据和代码)**
**若我们的教程对你有所帮助,请**点赞+收藏+转发**,这是对我们最大的支持。**
### 往期部分文章
**「1. 最全WGCNA教程(替换数据即可出全部结果与图形)」**
* (https://mp.weixin.qq.com/s?__biz=MzAwODY5NDU0MA==&mid=2455850466&idx=1&sn=6036fc2a19594f7fc38d65271f21e9cc&scene=21#wechat_redirect)
* (https://mp.weixin.qq.com/s?__biz=MzAwODY5NDU0MA==&mid=2455850727&idx=1&sn=1156c2bb0b0c9baff02838f5ffce39bf&scene=21#wechat_redirect)
* (https://mp.weixin.qq.com/s?__biz=MzAwODY5NDU0MA==&mid=2455850742&idx=1&sn=3d3eeedb3b58e536a83dc38d15725cd4&scene=21#wechat_redirect)
* (https://mp.weixin.qq.com/s?__biz=MzAwODY5NDU0MA==&mid=2455854728&idx=5&sn=bc98befb8dd0f0090bdfe69f3ffdb008&scene=21#wechat_redirect)
* (https://mp.weixin.qq.com/s?__biz=MzAwODY5NDU0MA==&mid=2455856103&idx=1&sn=774f8a084d21f757266f35c501c7155d&scene=21#wechat_redirect)
---
**「2. 精美图形绘制教程」**
* [精美图形绘制教程](https://mp.weixin.qq.com/mp/appmsgalbum?__biz=MzAwODY5NDU0MA==&action=getalbum&album_id=2614156000866385923&scene=173&from_msgid=2455848496&from_itemidx=1&count=3&nolastread=1#wechat_redirect)
**「3. 转录组分析教程」**
* **「**[转录组上游分析教程[零基础]](https://mp.weixin.qq.com/mp/appmsgalbum?__biz=MzAwODY5NDU0MA==&action=getalbum&album_id=2870608342451224581&scene=126&uin=&key=&devicetype=Windows+10+x64&version=63090719&lang=zh_CN&ascene=0)**」**
* **「**[一个转录组上游分析流程 | Hisat2-Stringtie](https://mp.weixin.qq.com/s?__biz=MzAwODY5NDU0MA==&mid=2455857417&idx=1&sn=653f3bdb0af386c22a128732ec8a01a4&scene=21#wechat_redirect)**」**
**「4. 转录组下游分析」**
* [批量做差异分析及图形绘制 | 基于DESeq2差异分析](https://mp.weixin.qq.com/s?__biz=MzAwODY5NDU0MA==&mid=2455860684&idx=1&sn=7be489c453cca737ad1092c6e4499827&scene=21#wechat_redirect)
* (https://mp.weixin.qq.com/s?__biz=MzAwODY5NDU0MA==&mid=2455859512&idx=1&sn=bac01a018f8b58afc7e2b3484f476bf4&scene=21#wechat_redirect)
* [单基因GSEA富集分析](https://mp.weixin.qq.com/s?__biz=MzAwODY5NDU0MA==&mid=2455859147&idx=1&sn=b022d80868e4b8014f64d443c82d1668&scene=21#wechat_redirect)
* [全基因集GSEA富集分析](https://mp.weixin.qq.com/s?__biz=MzAwODY5NDU0MA==&mid=2455860201&idx=1&sn=dd65c5b967123a876a6f5a38d4723ca6&scene=21#wechat_redirect)
**「小杜的生信筆記」** ,主要发表或收录生物信息学教程,以及基于R分析和可视化(包括数据分析,图形绘制等);分享感兴趣的文献和学习资料!!
页:
[1]