本文首发于“生信补给站”:https://mp.weixin.qq.com/s/8kz2oKvUQrCR2_HWYXQT4g

如果有maf格式的文件,可以直接oncoplot包绘制瀑布图,有多种展示和统计maftools | 从头开始绘制发表级oncoplot(瀑布图)maftools|TCGA肿瘤突变数据的汇总,分析和可视化,如果只有多个样本的基因突变与否的excel,不用担心,也可以用complexheatmap包绘制。

这个包功能很强大,本次只简单的介绍如何绘制基因组景观图(瀑布图)。

一 载入R包,数据

  1. #if (!requireNamespace("BiocManager", quietly = TRUE))
    # install.packages("BiocManager")
    #BiocManager::install("ComplexHeatmap")
    #install.packages("openxlsx")
    #install.packages("circlize")

    #后面直接加载即可
    library(openxlsx)
    library(ComplexHeatmap)
    library(circlize)
    #读入数据
    mut <- read.xlsx("TCGA_data.xlsx",sheet = "突变信息")
    cli <- read.xlsx("TCGA_data.xlsx",sheet = "临床信息")

查看变异数据

  1. rownames(mut) <- mut$sample
    mat <- mut[,-1]
    mat[is.na(mat)]<-""
    mat[1:6,1:6]

二 绘制突变景观图

2.0 绘制“初始”瀑布图

  1. oncoPrint(mat)

可以展示结果,但是为了paper,还需要一些调整!

2.1 指定变异类型的颜色和形状大小

  1. #指定颜色, 调整颜色代码即可
    col <- c( "mutation" = "blue" , "indel" = "green")
    #指定变异的样子,x,y,w,h代表变异的位置(x,y)和宽度(w),高度(h)
    alter_fun <- list(
     background = function(x, y, w, h) {
       grid.rect(x, y, w-unit(0.5, "mm"), h-unit(0.5, "mm"),
                 gp = gpar(fill = "#CCCCCC", col = NA))
    },
     mutation = function(x, y, w, h) {
       grid.rect(x, y, w-unit(0.5, "mm"), h-unit(0.5, "mm"),
                 gp = gpar(fill = col["mutation"], col = NA))
    },
     indel = function(x, y, w, h) {
       grid.rect(x, y, w-unit(0.5, "mm"), h*0.33,  
                 gp = gpar(fill = col["indel"], col = NA))
    }
    )

    #指定变异类型的标签,和数据中的类型对应
    heatmap_legend_param <- list(title = "Alternations",
                                at = c("mutation","indel"),
                                labels = c( "mutation","indel"))

绘制景观图

  1. #设定标题
    column_title <- "This is Oncoplot "  
    #画图并去除无突变的样本和基因
    oncoPrint(mat,
             alter_fun = alter_fun, col = col,
             column_title = column_title,
             heatmap_legend_param = heatmap_legend_param)

2.2 简单的调整

  1. oncoPrint(mat,
             alter_fun = alter_fun, col = col,
             column_title = column_title,
             remove_empty_columns = TRUE, #去掉空列
             remove_empty_rows = TRUE, #去掉空行
             row_names_side = "left", #基因在左
             pct_side = "right",
             heatmap_legend_param = heatmap_legend_param)

三 添加注释信息

3.1 指定临床注释信息

  1. pdata <- cli
    head(pdata)

  1. #对应患者
    pdata <- subset(pdata,pdata$sampleID %in% colnames(mat))
    mat <- mat[, pdata$sampleID]
    #定义注释信息
    ha<-HeatmapAnnotation(Age=pdata$age,
                         Gender=pdata$gender,
                         GeneExp_Subtype  = pdata$GeneExp_Subtype ,
                         censor = pdata$censor,
                         os = pdata$os,
                         show_annotation_name = TRUE,
                         annotation_name_gp = gpar(fontsize = 7))

3.2 瀑布图 + 临床注释

  1. oncoPrint(mat,
             bottom_annotation = ha, #注释信息在底部
             alter_fun = alter_fun, col = col,  
             column_title = column_title, heatmap_legend_param = heatmap_legend_param )

此处使用默认颜色注释,有时候会比较接近,且“变动”

3.3 自定义注释颜色以及顺序

  1. #自定义样本顺序
    s <- pdata[order(pdata$censor,pdata$GeneExp_Subtype),]
    sample_order <- as.character(s$sampleID)

    #自定义颜色
    #连续性变量设置颜色(外)
    col_os = colorRamp2(c(0, 4000), c("white", "red"))
    ha<-HeatmapAnnotation(Age=pdata$age,
                        Gender=pdata$gender,
                        GeneExp_Subtype  = pdata$GeneExp_Subtype ,
                        censor = pdata$censor,
                        os = pdata$os,
                        #指定颜色
                        col = list(censor = c("death" =  "red", "alive" = "blue"),
                                   GeneExp_Subtype = c("Classical" = "orange","Mesenchymal" = "green","Neural" = "skyblue" ),
                                   os = col_os),
                        show_annotation_name = TRUE,
                        annotation_name_gp = gpar(fontsize = 7))

绘制瀑布图

  1. oncoplot_anno = oncoPrint(mat,bottom_annotation = ha,
                alter_fun = alter_fun, col = col,
                column_order = sample_order,
                remove_empty_columns = TRUE, #去掉空列
                remove_empty_rows = TRUE, #去掉空行
                column_title = column_title, heatmap_legend_param = heatmap_legend_param)
    oncoplot_anno

注:颜色不一定好看,只是为了当默认的颜色比较接近时,或者有要求时候,可以自定义。

3.4 调整注释的位置

  1. draw(oncoplot_anno ,annotation_legend_side = "bottom")

更改注释的位置,方便后续拼图需求。

更多参数:

https://github.com/jokergoo/ComplexHeatmap

PS:觉得内容有帮助的话,可以点点在看和转发,新机制下容易失踪。

ComplexHeatmap|根据excel表绘制突变景观图(oncoplot)的更多相关文章

  1. 使用Excel 2007绘制甘特图

    本文将教大家如何使用Excel 2007制作甘特图.Excel并未提供甘特图类型,但还是可以绘制甘特图的,方法就是通过对堆积条形图类型进行自定义,使之显示任务.任务工期和层次结构. 下面的过程可帮助创 ...

  2. python爬取股票最新数据并用excel绘制树状图

    大家好,最近大A的白马股们简直 跌妈不认,作为重仓了抱团白马股基金的养鸡少年,每日那是一个以泪洗面啊. 不过从金融界最近一个交易日的大盘云图来看,其实很多中小股还是红色滴,绿的都是白马股们. 以下截图 ...

  3. ASPNET 导出EXCEL表

    其实网上有很多关于Excel的例子,但是不是很好,他们的代码没有很全,读的起来还很晦涩.经过这几天的摸索,终于可以完成我想要导出报表Excel的效果了.下面是我的效果图. 一.前台的页面图 GridV ...

  4. 用EXcel制作不同背景的图

    Excel 绘图区分区设置不同背景色 之 条形图 样图 在Excel图表中,如对绘图区设置背景色,一般只能对整个绘图区设置同一种颜色.图案或图片为背景.但有时希望能对不同的分区设置不同的颜色作为背景, ...

  5. excel表中内容如何反排列

    如题,我的意思是,比如excel表中有如下内容: 1.红色 2.黄色 3.蓝色 现在我需要一次性全部反向排列,变成 3.蓝色 2.黄色 1.红色 这不是纯数字排序,因为我序号不是自然数的等差数列,其中 ...

  6. ASP.NET导出excel表方法汇总

    asp.net里导出excel表方法汇总  1.由dataset生成 public void CreateExcel(DataSet ds,string typeid,string FileName) ...

  7. sql server数据库将excel表中的数据导入数据表

    一般有两种方法可以实现,一种是直接写sql语句,另外一种是利用sqlserver的管理工具实现.这里介绍的是后面一种方法. 步骤: 一.准备数据 1.将excel表另存为文本格式,注意文本格式需为ta ...

  8. 【Access2007】将Excel表导入到Access2007在现有的表成

    将Excel表导入到Access2007,你会发现邪恶Access2007这将帮助你自己主动创建表.您是否想插入完全没问你到一个现有的表. 然后,我们需要解决这个问题: 一.常的步骤先将Excel表导 ...

  9. 解决将Excel表导入到SQL Server数据库时出现Text was truncated or one or more characters had no match in the target code错误

    编写python爬虫程序可以在电商.旅游等网站上爬取相关评论数据,这些数据可以用于词云制作.感情词分析.提取关键词等,也可以将爬取下来的数据以自己的方式进行展示.评论数据爬取下来后,就要考虑怎样入库, ...

随机推荐

  1. 去掉shiro登录时url里的JSESSIONID https://blog.csdn.net/aofavx/article/details/51701012

    经过查找论坛和分析源码,确认了是在ShiroHttpServletResponse里加上的. 因此继承ShiroHttpServletResponse类,覆盖相应方法,再重写 ShiroFilterF ...

  2. html文本超出加省略号

    如果实现单行文本的溢出显示省略号同学们应该都知道用text-overflow:ellipsis属性来,当然还需要加宽度width属来兼容部分浏览. 实现方法: overflow: hidden; te ...

  3. Flink kuduSink开发

    1.继承RichSinkFunction (1)首先在构造方式传入kudu的masterAddress地址.默认表名.TableSerializationSchema.KuduTableRowConv ...

  4. 【JavaScript数据结构系列】04-优先队列PriorityQueue

    [JavaScript数据结构系列]04-优先队列PriorityQueue 码路工人 CoderMonkey 转载请注明作者与出处 ## 1. 认识优先级队列 经典的案例场景: 登机时经济舱的普通队 ...

  5. PIC单片机的i2c的程序

    #include<pic.h>#define uchar unsigned char#define uint unsigned int#define add 0xaa__CONFIG(0x ...

  6. debug PHP程序(xdebug、IntelliJ IDEA)

    之前写PHP程序的都是echo调试,今天感觉太麻烦了就想起研究一下IntelliJ IDEA如何调试PHP程序. 从网上查找了很多资料,大部分都提到在IDE里开启服务,一下就懵了,怎么启这么多服务呢. ...

  7. 小谢第6问:js中,filter函数是怎么使用的

    数组的常用方法filter,今天在做数组筛选的时候用到需要将有重复的数组去除,因此用到这个函数,主要用到-- 选择需要的属性,最终留下想要的数组,如果刚开始的话可以看下下面代码 let nums = ...

  8. Unity 游戏框架搭建 2019 (五十六/五十七) 需求分析-架构中最重要的一环&从 EmptyGO 到 Manager Of Managers

    我们的项目开始立项的时候,最常见的一个情况就是:几个人的小团队,一开始什么也不做,就开始写代码,验证逻辑,游戏就开始写起来了.而公司的一些所谓的领导层面一开始就把游戏定义为我们要做一个大作.这个事情本 ...

  9. prism.js——让网页中的代码更好看

    粗放的代码展示 有时候,网页中会插入代码.直接把代码放入<pre></pre>标签和<code></code>标签里,也算是可以在页面中显示出来. 比如 ...

  10. 点击label时text输入框被选中

    当点击label标签时,能够选中与其对应的输入框,有2种方式,采用第一种时会产生太多的id,推荐第二种. <form action="03.php"> <labe ...