記錄一次venn圖的繪制

目的

  • 使用從文件中提取的四組數(shù)據繪制venn圖魄鸦,并保存各自獨有的數(shù)據以及用來制作venn圖的原始數(shù)據
  • 分別提取fpkm<0.3的列窿克,保存數(shù)據并繪制venn圖
  • 保存venn中獨有的部分

思路

  • which進行判斷比較啊~~
  • venn圖使用:VennDiagram這個包纵竖,照著示例代碼走就行了催什,抄的時候薄啥,要注意
    list中x=xx,y=xxx,一定要注明鸦列,
    我就在這報了好久的錯。
#獲取skin1-4各自符合條件的gene_id行搪花,并使用四組數(shù)據繪制venn圖
#通過修改fpkm閾值遏片,產生不同的venn圖,以及相關數(shù)據撮竿,其中alone可用于單獨提取數(shù)據
#state:complete
#2019年1月12日16:11:42
#author:liyuan


#step1:initial
#step1_1:load main file
setwd("~/R_Workspace/DATA/1-11/4_特異表達venn/")
library(data.table)
input_table <- fread("~/R_Workspace/DATA/1-11/gene.description.xls",
                          header = T,sep="\t",
                          fill=T,quote = "",check.names = F);paste("step1_1_load main file success!")
#step1_2:set params
fpkm <- 10;paste("step_1_2_params_set_success!!")
prefix<-paste("fpkm",fpkm,"/exp.venn",sep="")
out_file_skin1 <- paste(prefix,".skin1.fpkm",fpkm,".xls",sep="")
out_file_skin2 <- paste(prefix,".skin2.fpkm",fpkm,".xls",sep="")
out_file_skin3 <- paste(prefix,".skin3.fpkm",fpkm,".xls",sep="")
out_file_skin4 <- paste(prefix,".skin4.fpkm",fpkm,".xls",sep="")
out_file_venn <- paste(prefix,".skin1-4.fpkm",fpkm,".tiff",sep="")


#step2:get data
#step2_1:ensure which column and edit clean the column
#geneid:1,skin1:56,skin2:55,skin3:67,skin4:51,anno:176:185
#1,anno the gene
#2,rename the sample
skin_name<-c(paste("skin-",c("B","C","RW","W"),sep = ""))
skin_col <- c(56,55,67,51)

colnames(input_table)[skin_col] <- paste(skin_name,
                            sep="");paste("2_1_1_colnames update success!!")
#注:字符串替換并不改變原來的
library(stringr)
input_table$Gene.Name <- str_replace_all(input_table$KEGG.AnnotInfo,
                                     pattern = "(^.*RefSeq\\) )|(\\;.*$)",replacement = "");paste("2_1_2_gene_anno success!!")

#step2_2,get data
skin1_data <- input_table[which(input_table[,56]>=fpkm),] #get row
skin2_data <- input_table[which(input_table[,55]>=fpkm),] #get row
skin3_data <- input_table[which(input_table[,67]>=fpkm),] #get row
skin4_data <- input_table[which(input_table[,51]>=fpkm),] #get row

write.table(skin1_data[,c(1,skin_col,176:185)],row.names = FALSE,file=out_file_skin1,sep="\t")
write.table(skin2_data[,c(1,skin_col,176:185)],row.names = FALSE,file=out_file_skin2,sep="\t")
write.table(skin3_data[,c(1,skin_col,176:185)],row.names = FALSE,file=out_file_skin3,sep="\t")
write.table(skin4_data[,c(1,skin_col,176:185)],row.names = FALSE,file=out_file_skin4,sep="\t")

# for(i in 1:4){
#   write.table(input_table[which(input_table[,skin_col[i]]>=fpkm),],
#               file=paste("./R_Workspace/DATA/1-11/venn.skin",i,".fpkm",fpkm,".xls",sep="\t"))
#   
# }

#step3,draw venn
library(VennDiagram)
venn_data = list(
  "skin-B" = skin1_data$Gene_id,
  "skin-C" = skin2_data$Gene_id,
  "skin-RW" = skin3_data$Gene_id,
  "skin-W" = skin4_data$Gene_id
)
venn.plot <- venn.diagram(
  venn_data,filename = out_file_venn,
  col = "black",
  #fill = c("dodgerblue", "goldenrod1", "darkorange1", "seagreen3", "orchid3"),
  fill = c("dodgerblue", "goldenrod1", "darkorange1", "seagreen3"),
  alpha = 0.50,
  #cex = c(1.5, 1.5, 1.5, 1.5, 1.5, 1, 0.8, 1, 0.8, 1, 0.8, 1, 0.8,
   #       1, 0.8, 1, 0.55, 1, 0.55, 1, 0.55, 1, 0.55, 1, 0.55, 1, 1, 1, 1, 1, 1.5),
  #cat.col = c("dodgerblue", "goldenrod1", "darkorange1", "seagreen3", "orchid3"),
  cat.col = c("dodgerblue", "goldenrod1", "darkorange1", "seagreen3"),
  cat.cex = 1.5,
  cat.fontface = "bold",
  margin = 0.05
);paste("step3_venn_draw_success!!")

#step4,save venn intersection_data
area=calculate.overlap(venn_data)
#typeof(area)
#summary(area)
#a9-skinB;a14-skinC;a1-skinRW;a3-skinW
write.table(area$a9,file=paste(out_file_skin1,"_alone.xls",sep=""),sep="\t",row.names = F,col.names = F)
write.table(area$a14,file=paste(out_file_skin2,"_alone.xls",sep=""),sep="\t",row.names = F,col.names = F)
write.table(area$a1,file=paste(out_file_skin3,"_alone.xls",sep=""),sep="\t",row.names = F,col.names = F)
write.table(area$a3,file=paste(out_file_skin4,"_alone.xls",sep=""),sep="\t",row.names = F,col.names = F)
paste("step4_table_of_alone_write_success!!")
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末吮便,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子幢踏,更是在濱河造成了極大的恐慌髓需,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件房蝉,死亡現(xiàn)場離奇詭異僚匆,居然都是意外死亡,警方通過查閱死者的電腦和手機搭幻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進店門咧擂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人檀蹋,你說我怎么就攤上這事松申。” “怎么了俯逾?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵贸桶,是天一觀的道長。 經常有香客問我纱昧,道長刨啸,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任识脆,我火速辦了婚禮设联,結果婚禮上,老公的妹妹穿的比我還像新娘灼捂。我一直安慰自己离例,他們只是感情好,可當我...
    茶點故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布悉稠。 她就那樣靜靜地躺著宫蛆,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上耀盗,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天想虎,我揣著相機與錄音,去河邊找鬼叛拷。 笑死舌厨,一個胖子當著我的面吹牛,可吹牛的內容都是我干的忿薇。 我是一名探鬼主播裙椭,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼署浩!你這毒婦竟也來了揉燃?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤筋栋,失蹤者是張志新(化名)和其女友劉穎炊汤,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體二汛,經...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡婿崭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了肴颊。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡渣磷,死狀恐怖婿着,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情醋界,我是刑警寧澤竟宋,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站形纺,受9級特大地震影響丘侠,放射性物質發(fā)生泄漏。R本人自食惡果不足惜逐样,卻給世界環(huán)境...
    茶點故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一蜗字、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧脂新,春花似錦挪捕、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至滞乙,卻和暖如春奏纪,著一層夾襖步出監(jiān)牢的瞬間鉴嗤,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工序调, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留醉锅,地道東北人。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓炕置,卻偏偏與公主長得像荣挨,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子朴摊,可洞房花燭夜當晚...
    茶點故事閱讀 42,901評論 2 345

推薦閱讀更多精彩內容