用ggplot2做富集分析气泡图

数据准备

富集分析软件
由于做的材料不是模式植物,用clusterProfiler上面配置起来有点困难,最要命的是基因组数据库并没有上传NCBI,无法用OrgDb,当然也可以自己做background然后做富集,折腾了好久还是有各种问题...打算等以后有空了再好好折腾吧,毕竟脚尖还没踏进R的大门。

最后选择用CJ大神的TBtools做富集分析,这次以go富集分析为例,需要自己准备的有基因ID对应GOID的一个Background,go-basis.obo直接在软件中下载。根据教程一步一步做完就得到了。(大神更新软件速度较快,建议加TBtools群,实时更新)

TBtools富集分析输出结果

一会需要的数据就是图中箭头指出的这几行,建议把最后corrected p-value(BH-method)改成qvalue,为了在R里面稍微少打点字,嘿嘿。
此外,这次富集出来180多条go注释,太多了,画出的图太长,所以首先筛选了qvalue<0.05的,还是有100多条,然后选了各个class(BP MF CC)的top15,此外在这里建议对EnrichmentScore这一列A-Z排序,然后再对Class排序,(这里主要是为了在展示的时候纵向上把同一个class的GO term防在一起,横向上按照enrichmentScore从小到大排列,此外,在其他的bubble chart中有人用GeneRatio作为横坐标,那么用HitsGenesCountsInSelectedSet除以AllGenesCountsInSelectedSet表头写上GeneRatio;此外如果出现qvalue为0的term,建议把0改成1E-100,不然最后这些0值被-log后会出现na,na则会显示为灰色,为了避免R下面复杂的操作这里最好改成无限接近于0的数字。(这应该不算改数据吧?)准备好后另存为格式为制表符分隔符的文本(.txt)

用ggplot2画bubble chart

  1. 设置工作路径:打开Rstudio→Session→Set Working Directory→Choose Directory,然后选择你刚才保存文件的文件夹,也可以直接setwd("~/Dropbox/xxx")
  2. 画图
##加载ggplot2包
library(ggplot2)
##读取刚才保存的富集分析结果文件
goinput <- read.table("test.txt",header = T,sep = "\t")##header = T 第一行是表头,sep = "\t"表示以制表符(tab)分割
##利用levels来设置factor中的顺序,保证最后出图时按照我们之前排好的顺序排列
x=goinput$EnrichmentScore
y=factor(goinput$GO_Name,levels = goinput$GO_Name)
##先出一个框架
p = ggplot(goinput,aes(x,y))
##数据特征包括bubble大小来源为匹配到这个term上的基因数,颜色为qvalue,颜色变化为从低到高:"SpringGreen"到"DeepPink"而类型则是class,
p1 = p + geom_point(aes(size=HitsGenesCountsInSelectedSet,color=-1*log(Qvalue),shape=Class,))+
  scale_color_gradient(low = "SpringGreen", high = "DeepPink")
##设置横纵坐标名字,标题,legend名字
p2 = p1 + labs(color=expression(-log[10](Qvalue)),
                    size="Gene Number",
                    x="EnrichmentScore",
                    y="Go_term",
                    title="Go enrichment of test Genes")
##搞个主题,把边框画出来也可以通过ggplot Theme assistant修改
p3 = p2 +theme_bw() 
p3
P1主要信息录入.jpeg
p2各标题名称改好.jpeg
P3最后修改主题.jpeg
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335

推荐阅读更多精彩内容