我一直在尝试在由 R 中的 pheatmap 创建的热图中添加行注释。基本上我有一个 csv 文件,其中包含一个特定列(组),用于热图中的行注释。但是,我的以下代码有问题。另外两个问题是:标题的字体大小显然太大,但我找不到减小它的方法。而且我想将任何零的值设置为纯白色,但我不确定它在我的输出文件中是否真的是白色。输入 csv 文件和输出 pdf 文件是链接的。我在这里坚持使用 pheatmap,因为我发现它创建的热图比其他热图功能更适合我的需要。建议表示赞赏。
> library("pheatmap")
> data <- read.csv("/Users/neo/Test_BP_052215.csv", header = TRUE, row.names = 2, stringsAsFactors=F)
> head(data)
Group WT KO1 KO2
GO:0018904 organic ether metabolic process Metabolism 12.17372951 0.000000 -15.006995
GO:0006641 triglyceride metabolic process Metabolism 5.200847907 0.000000 0.000000
GO:0045444 fat cell differentiation Metabolism 6.374521098 0.000000 -7.927192
GO:0006639 acylglycerol metabolic process Metabolism 6.028616852 0.000000 0.000000
GO:0016125 sterol metabolic process Metabolism 5.760678325 8.262778 0.000000
GO:0016126 sterol biosynthetic process Metabolism -6.237114754 9.622373 0.000000
> heatdata <- data[,-1]
> head(heatdata)
WT KO1 KO2
GO:0018904 organic ether metabolic process 12.17372951 0.000000 -15.006995
GO:0006641 triglyceride metabolic process 5.200847907 0.000000 0.000000
GO:0045444 fat cell differentiation 6.374521098 0.000000 -7.927192
GO:0006639 acylglycerol metabolic process 6.028616852 0.000000 0.000000
GO:0016125 sterol metabolic process 5.760678325 8.262778 0.000000
GO:0016126 sterol biosynthetic process -6.237114754 9.622373 0.000000
> annotation_row <- data.frame(Group = data[,1])
> rownames(annotation_row) = paste("Group", 1:38, sep = "")
> ann_colors = list( Group = c(Metabolism="navy", Cellular="skyblue", Signal="steelblue", Transport="green", Cell="purple", Protein="yellow", Other="firebrick") )
> head(annotation_row)
Group
Group1 Metabolism
Group2 Metabolism
Group3 Metabolism
Group4 Metabolism
Group5 Metabolism
Group6 Metabolism
> col_breaks = unique(c(seq(-16,-0.5,length=200), seq(-0.5,0.5,length=200), seq(0.5,20,length=200)))
> my_palette <- colorRampPalette(c("blue", "white", "red"))(n = 599)
> pheatmap(heatdata, main="Enrichment", color=my_palette, breaks=col_breaks, border_color = "grey20", cellwidth = 15, cellheight = 12, scale = "none", annotation_row = annotation_row, annotation_colors = ann_colors, cluster_rows = F, cluster_cols=F, fontsize_row=10, filename="heatmap_BP_test.pdf")