DU2:如何准确获取基因的某个保守区域序列

需要解决的问题:

准确获取基因X的某个保守区域H的蛋白序列及核酸序列,查看该段序列蛋白层面及核酸层面的变化情况。

分析:

需要获取的基因X的某个保守区域序列H中有几个氨基酸非常保守,先进行序列比对,定位该段保守序列,提取该段序列,考虑到取到的序列中含有gap的情况,需要将获取的序列(去除“-”)重新在物种W的蛋白序列中定位再次提取,保证氨基酸数目的一致;定位得到的蛋白序列起始终止位置的坐标乘以3即得到核酸序列的坐标信息,从物种W的CDS序列文件中提取该保守区段H的核酸序列。

解决方案:

1、使用muscle将基因X的蛋白序列进行比对,并在Jalview中进行可视化

muscle -in W-X.fas -out W-X.fas.aln -maxiters 1000
基因X序列比对

序列过长过短都会造成比对结果中产生gap,手动查看并删除造成很长gap的序列;
Ctrl+F定位该保守区段在比对文件中的位置,如上图确认PGRTDN出现的起始位置为123;
在Jalview中导出筛选之后的序列比对文件。
防止出错,去除比对文件的换行符

awk '!/^>/ { printf "%s", $0; n = "\n" } /^>/ { print n $0; n = "" } END { printf "%s", n } ' W_X_filter_aln.fas.aln > W_X_filter_aln.fas.aln.nochangeline

2、写脚本从aln比对文件中按保守区域H的比对起始终止位置提取序列并去除gap(18个氨基酸)

#!/usr/bin/env python
# -*- coding:utf-8 -*-
import sys
import re
File = sys.argv[1]
input_file = open(File,'r')
start = input("请输入保守区域的起始位置:")
end = int(start) + 18
prefix = sys.argv[1].split(".")[0]
output_file = open ('%s_H.pep'%(prefix), 'w')
for line in input_file:
    line = line.rstrip()
    if not line: break
    if '>' in line:
        print(line,file = output_file)
    else:
        line = line[int(start):int(end)]
        if "-" in line:
            line = line.replace("-", "")
            print(line,file = output_file)
        else:
            print(line,file = output_file)
input_file.close()
output_file.close()

#运行命令
python extract_H_pepseq.py W_X_filter_aln.fas.aln.nochangeline
请输入保守区域的起始位置:123

输出文件为W_X_filter_aln_H.pep

3、从比对文件中提取的序列可能有gap,因此可能不足18个氨基酸,因此需要在原始蛋白序列文件中重新提取保证所有保守区域都是提取出18个氨基酸;
用脚本确定这些保守序列在原始蛋白序列中的起始终止位置

#!/usr/bin/env python
# -*- coding:utf-8 -*-
import sys
import re
File1 = sys.argv[1]
File2 = sys.argv[2]
input_file1 = open(File1,'r')
input_file2 = open(File2,'r')
prefix = sys.argv[2].split(".")[0]
output_file1 = open ('%s.peppos'%(prefix), 'w')
output_file2 = open ('%s.CDSpos'%(prefix), 'w')
Dict1 = dict()
Dict2 = dict()
for line1 in input_file1:
    line1 = line1.rstrip()
    if not line1: break
    if '>' in line1:
        idline1 = line1
    else:
        Dict1[idline1] = line1
for line2 in input_file2:
    line2 = line2.rstrip()
    if not line2:break  
    if '>' in line2:
        idline2 = line2
    else:
        Dict2[idline2] = line2
for key2,value2 in Dict2.items():
    for key1,value1 in Dict1.items():
        if key2 == key1:
            start = int(value1.find(value2)) + 1
            end = int(start) + 17
            print(key2.replace(">",""),start,end,file = output_file1)
            print(key2.replace(">",""),int(start)*3,int(end)*3+3,file = output_file2)
input_file1.close()
input_file2.close()
output_file1.close()
output_file2.close()

#运行命令
python find_Hpep_pos.py ../W.pep W_X_filter_aln_H.pep

输出文件为W_X_filter_aln_H.peppos和W_X_filter_aln_H.CDSpos
输出文件的格式如下:
<ID号> <起始位置> <终止位置>

** 4、以上准备工作做完后用TBtools提取序列并出seqlogo图**
用TBtools提取序列

java -cp TBtools_JRE1.6.jar biocjava.bioIO.FastX.FastaIndex.SeqExtracterAccordingFAindex --inFA ../W.pep --regionList W_X_filter_aln_H.peppos --outFA W_X_H.pep
java -cp TBtools_JRE1.6.jar biocjava.bioIO.FastX.FastaIndex.SeqExtracterAccordingFAindex --inFA ../W.CDS --regionList W_X_filter_aln_H.CDSpos --outFA W_X_H.CDS

用TBtools出seqlogo图

java -cp TBtools_JRE1.6.jar biocjava.bioDoer.seqLogo.makeSeqLogo --inFile W_X_H.pep --borderSize 5 --borderColor 0,0,0 --scaleIC true --OutGraph W_X_H.pep.png
java -cp TBtools_JRE1.6.jar biocjava.bioDoer.seqLogo.makeSeqLogo --inFile W_X_H.CDS --borderSize 5 --borderColor 0,0,0 --scaleIC true --OutGraph W_X_H.CDS.png

完成!!!

H蛋白序列

H核酸序列

5、TBtools新工具makeSeqLogo命令行介绍
Usage

--inFile 必选,输入文件,可以是一行一条序列也可以是fasta格式文件
--scaleIC 可选,默认为false,改为true会使得保守位点更加明显
--OutGraph 必选,出图,文件后缀决定格式如.png或.pdf
--showPos 可选,默认为false,seqlogo下方不显示consensus序列,而显示位置信息
--startPos 可选,默认为1,位置的起始坐标
--borderColor 可选,默认为255,255,255 白色,边框的颜色
--borderSize 可选,默认为2,边框线条的粗细
--onlyBorder 可选,默认为false,改为true则只显示边框,不填充颜色
--xInterval 可选,默认为1,改变x轴的间距
--yInterval 可选,默认为1,改变y轴的间距
不选择 --scaleIC的变化如下:

java -cp TBtools_JRE1.6.jar biocjava.bioDoer.seqLogo.makeSeqLogo --inFile W_X_H.pep --borderSize 5 --borderColor 0,0,0 --OutGraph W_X_H.pep1.png
--scaleIC false

选择 --onlyBorder的变化如下:

java -cp TBtools_JRE1.6.jar biocjava.bioDoer.seqLogo.makeSeqLogo --inFile W_X_H.pep --borderSize 5 --borderColor 0,0,0 --scaleIC true --onlyBorder true --OutGraph W_X_H.pep2.png
--onlyBorder true

改变x轴和y轴的间距

java -cp TBtools_JRE1.6.jar biocjava.bioDoer.seqLogo.makeSeqLogo --inFile W_X_H.pep --borderSize 5 --borderColor 0,0,0 --scaleIC true --xInterval 5 --yInterval 5 --OutGraph W_X_H.pep3.png
间距1--5
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352