外显子Bed文件制作

#coding

使用gencode的人类GFF制作一个基于Mane Select转录本(Refseq版本)的外显子Bed文件。

首先下载gff文件。是的,还是使用的GRCh37。

wget https://ftp.ebi.ac.uk/pub/databases/gencode/Gencode_human/release_46/GRCh37_mapping/gencode.v46lift37.annotation.gff3.gz

然后把mane select和exon部分提取出来

zcat gencode.v46lift37.annotation.gff3.gz | grep "MANE_Select" | grep "ID=exon" > grch37.mane.exon.gff3

但是,由于gencode这里面是Ensembl的转录本编号,我们一般使用的都是Refseq编号,因此还要将编号对应回去。

下载这个下面这个Refseq的GRCh38的gff用于匹配Ensembl和Refseq的转录本(如果是需要GRCh38的bed,那就只用下面这个文件就好,我在NCBI官网找不到GRCh37的gff)。

wget https://ftp.ncbi.nlm.nih.gov/refseq/MANE/MANE_human/release_1.3/MANE.GRCh38.v1.3.refseq_genomic.gff.gz
gunzip MANE.GRCh38.v1.3.refseq_genomic.gff.gz

接下来让撸个脚本进行处理

# python3

transcript_dict = {}
with open("MANE.GRCh38.v1.3.refseq_genomic.gff", "r") as f:
    for line in f:
        if line.startswith("#"):
            continue
        ensembl = refseq = "."
        lines = line.rstrip().split("\t")
        if (lines[2] == "exon") and ("tag=MANE Select" in line):
            info_fields = lines[8].split(";")
            for i in info_fields:
                if i.startswith("Dbxref"):
                    dbxrefs = i.lstrip("Dbxref=").split(",")
                    for d in dbxrefs:
                        if d.startswith("Ensembl:"):
                            ensembl = d.split("Ensembl:")[1]
                elif i.startswith("transcript_id="):
                    refseq = i.split("transcript_id=")[1]
        if not any([ensembl == ".", refseq == "."]):
            transcript_dict[ensembl] = refseq

output_bed = open("GRCh37.Gencode.ManeSelect.Exon.bed", "w", encoding="utf-8")
output_bed.write("#Chrom\tStart\tEnd\tRegion\tGene\tEnsembl\tRefseq\tStrand\n")

with open("grch37.mane.exon.gff3", "r") as gff_file:
    for line in gff_file:
        if not line.startswith("#"):
            fields = line.rstrip().split("\t")
            info_fields = fields[8].split(";")
            gene = ensembl = exon = "."
            for i in info_fields:
                if i.startswith("Parent"):
                    ensembl = i.split("=")[1]
                elif i.startswith("gene_name"):
                    gene = i.split("=")[1]
                elif i.startswith("exon_number"):
                    exon = "exon" + i.split("=")[1]
            if ensembl in transcript_dict:
                refseq = transcript_dict[ensembl]
            output_list = [fields[0], fields[3], fields[4], exon, gene, ensembl, refseq, fields[6]]
            output_bed.write("\t".join(output_list) + "\n")

output_bed.close()

如果需要的是CDS区域的话,就调整一下筛选就可以了。另外这里不会输出Ensembl和Refseq无对照的转录本,需要注意一下。

都4202年了,到底是谁还在用GRCh37啊。~~某委只要一声令下,往后的所有质评都只用GRCh38,还不是纷纷响应的。~~要知道GRCh38都已经推出超过10年了,还拿数据库不完善说事呢,我主要感觉现在找GRCh37的资源比找GRCh38困难多了:joy:。