查看原文
其他

ID转换大全

2017-03-15 x2yline 生信技能树

实际上掌握了编程的思维,任何一门语言都可以做id转换!
对于初学者来说,这个是非常实用的一个,很多人当初就是因为要做这个转换,才慢慢走入了编程的道路。
使用大部分软件的时候,第一步就是文件数据准备,基本上都是数据的拆分和整合,这个拿id转换做基础练习也挺好的!
本来应该作为第一讲,但是当初认为太基础了,而忽略掉了,放在这里也好,大部分同学已经跟我们学习两个月了,可以拿这个题目来检验自己的水平了!
ID转换简单来说,就是找到对应关系表,然后用hash或者字典对应一下即可。但也可以很复杂:

为什么要转换id?
有多少种ID?
什么id权威?
id是一一对应的吗?
ID是什么生信组织维护?
id有版本吗?
id一定正确吗?
什么情况下选择什么id?
不同数据库下载的id对应表一定一样吗?


你们看我的博客,就知道,我是如何重视ID转换的:




还有论坛里面的:生信人必须了解的各种ID表示方式


当然,我们时间有限,不可能面面俱到,很多东西都是需要自己去慢慢挖掘的!
需要集中学习的是 entrez gene ID, HUGO symbol, refseq ID, ensembl ID

作业,就是用perl,python,R
来把1~1000 这1000个 entrez gene ID转为另外3个吧,如果该entrez gene ID不存在,就不用转了。

请自己下载基因ID的对应关系文件,参考
,  

最后:
请务必把下面的代码运行一下,把输出
的all_gene_bioconductor.html文件好好看看!

 

  1. rm(list=ls())

  2. library(org.Hs.eg.db)

  3. eg2symbol=toTable(org.Hs.egSYMBOL)

  4. eg2name=toTable(org.Hs.egGENENAME)

  5. eg2alias=toTable(org.Hs.egALIAS2EG)

  6. eg2alis_list=lapply(split(eg2alias,eg2alias$gene_id),function(x){paste0(x[,2],collapse = ";")})

  7. GeneList=mappedLkeys(org.Hs.egSYMBOL)

  8. if( GeneList[1] %in% eg2symbol$symbol ){

  9.  symbols=GeneList

  10.  geneIds=eg2symbol[match(symbols,eg2symbol$symbol),'gene_id']

  11. }else{

  12.  geneIds=GeneList

  13.  symbols=eg2symbol[match(geneIds,eg2symbol$gene_id),'symbol']

  14. }

  15. geneNames=eg2name[match(geneIds,eg2name$gene_id),'gene_name']

  16. geneAlias=sapply(geneIds,function(x){ifelse(is.null(eg2alis_list[[x]]),"no_alias",eg2alis_list[[x]])})

  17. createLink <- function(base,val) {

  18.   sprintf('<a href="%s" class="btn btn-link" target="_blank" >%s</a>',base,val) ##target="_blank"

  19. }

  20. gene_info=data.frame(   symbols=symbols,

  21.                        geneIds=createLink(paste0("http://www.ncbi.nlm.nih.gov/gene/",geneIds),geneIds),

  22.                        geneNames=geneNames,

  23.                        geneAlias=geneAlias,

  24.                        stringsAsFactors = F

  25. )

  26. #library("xtable")

  27. #print(xtable(gene_info), type="html",include.rownames=F, file='all_gene.anno',sanitize.text.function = force)

  28. file='all_gene_bioconductor.html'

  29. y <- DT::datatable(gene_info,escape = F,rownames=F)

  30. DT::saveWidget(y,file)


排版有点麻烦,请直接点击阅读原文去查看吧~~~

PS:这个代码非常经典,值得大家用心学习

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存