资讯专栏INFORMATION COLUMN

应用Python脚本制作获取基因组测序指定位置编码序列

89542767 / 490人阅读

     此篇文章关键给大家介绍了应用Python脚本制作获取基因组测序指定位置编码序列的实例详细说明,感兴趣的小伙伴值得借鉴参考一下,也希望能有一定的帮助,祝愿大家多多的发展,尽早涨薪


  前言


  在基因组分析中,大家常常会有这样一个要求,便是在一个fasta文件中获取某些编码序列出去。有时候这种编码序列注定是完备的编码序列,而有时候只是为原fasta文件中某一段编码序列中的一部分。尤其是当信息量许多时,应用人眼来挑选编码序列会很费劲,因此这个时候大家就可以用编程逻辑去完成了。


  比如这里在百度云盘配件中给出了某种群全基因组序列(0-refer/Bacillus_subtilis.str168.fasta),及其基因组测序gff注解文件(0-refer/Bacillus_subtilis.str168.gff)。


  假定在这儿对于该种群进行分析,根据gff注解文档中的基因功能叙述字段名,再加上对相关信息的查阅等,精准定位到了一部分特定的基因。


  下面我们期待基于gff文件中对这种遗传基因部位的描写,在这一基因组序列fasta文件里将这种遗传基因寻找并分离出来,获得了一个新的fasta文件,新文件上只包括目地基因序列。


  请使用python3撰写1个能够实现这个功能的脚本制作。


  示例


  一个示例脚本如下(可参见网盘附件“seq_select1.py”)。

01.png

  为了实现以上目的,我们首先需要准备一个txt文件(以下称其为list文件,示例list.txt可参见网盘附件),基于gff文件中所记录的基因位置信息,填入类似以下的内容(列与列之间以tab分隔)。


  #下列内容保存到list.txt


  gene46 NC_000964.3 42917 43660+
  NP_387934.1 NC_000964.3 59504 60070+
  yfmC NC_000964.3 825787 826734-
  cds821 NC_000964.3 885844 886173-


  第1列,给所要获取的新序列命个名称;


  第2列,所要获取的序列所在原序列ID;


  第3列,所要获取的序列在原序列中的起始位置;


  第4列,所要获取的序列在原序列中的终止位置;


  第5列,所要获取的序列位于原序列的正链(+)或负链(-)。


  之后根据输入文件,即输入fasta文件及记录所要获取序列位置的list文件中的内容,编辑py脚本。


  打开fasta文件“Bacillus_subtilis.scaffolds.fasta”,使用循环逐行读取其中的序列id及碱基序列,并将每条序列的所有碱基合并为一个字符串;将序列id及该序列合并后的碱基序列以字典的形式存储(字典样式{'id':'base'})。


  打开list文件“list.txt”,读取其中的内容,存储到字典中。字典的键为list文件中的第1列内容;字典的值为list文件中第2-5列的内容,并按tab分割得到一个列表,包含4个字符分别代表list文件中第2-5列的信息)。


  最后根据读取的list文件中序列位置信息,在读取的基因组中截取目的基因序列。由于某些基因序列可能位于基因组负链中,需取其反向互补序列,故首先定义一个函数rev(),用于在后续调用得到反向互补序列。在输出序列名称时,还可选是否将该序列的位置信息一并输出(name_detail=True/False)。


  <pre class="r"style="overflow-wrap:break-word;font-style:normal;font-variant-ligatures:normal;font-variant-caps:normal;font-weight:400;letter-spacing:normal;orphans:2;text-align:start;text-indent:0px;text-transform:none;widows:2;word-spacing:0px;-webkit-text-stroke-width:0px;text-decoration-style:initial;text-decoration-color:initial;margin-top:0px;margin-bottom:10px;padding:9.5px;border-radius:4px;background-color:rgb(245,245,245);box-sizing:border-box;overflow:auto;font-size:13px;line-height:1.42857;color:rgb(51,51,51);word-break:break-all;border:1px solid rgb(204,204,204);font-family:"Times New Roman";">#!/usr/bin/env python3


  #-*-coding:utf-8-*-
  #初始传递命令
  input_file='Bacillus_subtilis.str168.fasta'
  list_file='list.txt'
  output_file='gene.fasta'
  name_detail=True
  ##读取文件
  #读取基因组序列
  seq_file={}
  with open(input_file,'r')as input_fasta:
  for line in input_fasta:
  line=line.strip()
  if line[0]=='>':
  seq_id=line.split()[0]
  seq_file[seq_id]=''
  else:
  seq_file[seq_id]+=line
  input_fasta.close()
  #读取列表文件
  list_dict={}
  with open(list_file,'r')as list_table:
  for line in list_table:
  if line.strip():
  line=line.strip().split('t')
  list_dict[line[0]]=[line[1],int(line[2])-1,int(line[3]),line[4]]
  list_table.close()
  ##截取序列并输出
  #定义函数,用于截取反向互补
  def rev(seq):
  base_trans={'A':'T','C':'G','T':'A','G':'C','N':'N','a':'t','c':'g','t':'a','g':'c','n':'n'}
  rev_seq=list(reversed(seq))
  rev_seq_list=[base_trans[k]for k in rev_seq]
  rev_seq=''.join(rev_seq_list)
  return(rev_seq)
  #截取序列并输出
  output_fasta=open(output_file,'w')
  for key,value in list_dict.items():
  if name_detail:
  print('>'+key,'['+value[0],value[1]+1,value[2],value[3]+']',file=output_fasta)
  else:
  print('>'+key,file=output_fasta)
  seq=seq_file['>'+value[0]][value[1]:value[2]]
  if value[3]=='+':
  print(seq,file=output_fasta)
  elif value[3]=='-':
  seq=rev(seq)
  print(seq,file=output_fasta)
  output_fasta.close()</pre>


  编辑该脚本后运行,输出新的fasta文件“gene.fasta”,其中的序列即为我们所想要得到的目的基因序列。

02.png

  扩展:


  网盘附件“seq_select.py”为添加了命令传递行的python3脚本,可在shell中直接进行目标文件的I/O处理。该脚本可指定输入fasta序列文件以及记录有所需提取序列位置的列表文件,输出的新fasta文件即为提取出的序列。


  #!/usr/bin/env python3
  #-*-coding:utf-8-*-
  #导入模块,初始传递命令、变量等
  import argparse
  parser=argparse.ArgumentParser(description='n该脚本用于在基因组特定位置截取序列,需额外输入记录有截取序列信息的列表文件',add_help=False,usage='npython3 seq_select.py-i[input.fasta]-o[output.fasta]-l<ul>npython3 seq_select.py--input[input.fasta]--output[output.fasta]--list<ul>')
  required=parser.add_argument_group('必选项')
  optional=parser.add_argument_group('可选项')
  required.add_argument('-i','--input',metavar='[input.fasta]',help='输入文件,fasta格式',required=True)
  required.add_argument('-o','--output',metavar='[output.fasta]',help='输出文件,fasta格式',required=True)
  required.add_argument('-l','--list',metavar='<ul>',help='记录“新序列名称/序列所在原序列ID/序列起始位置/序列终止位置/正链(+)或负链(-)”的文件,以tab作为分隔',required=True)
  optional.add_argument('--detail',action='store_true',help='若该参数存在,则在输出fasta的每条序列id中展示序列在原fasta中的位置信息',required=False)
  optional.add_argument('-h','--help',action='help',help='帮助信息')
  args=parser.parse_args()
  ##读取文件
  #读取基因组序列
  seq_file={}
  with open(args.input,'r')as input_fasta:
  for line in input_fasta:
  line=line.strip()
  if line[0]=='>':
  seq_id=line.split()[0]
  seq_file[seq_id]=''
  else:
  seq_file[seq_id]+=line
  input_fasta.close()
  #读取列表文件
  list_dict={}
  with open(args.list,'r')as list_file:
  for line in list_file:
  if line.strip():
  line=line.strip().split('t')
  list_dict[line[0]]=[line[1],int(line[2])-1,int(line[3]),line[4]]
  list_file.close()
  ##截取序列并输出
  #定义函数,用于截取反向互补
  def rev(seq):
  base_trans={'A':'T','C':'G','T':'A','G':'C','a':'t','c':'g','t':'a','g':'c'}
  rev_seq=list(reversed(seq))
  rev_seq_list=[base_trans[k]for k in rev_seq]
  rev_seq=''.join(rev_seq_list)
  return(rev_seq)
  #截取序列并输出
  output_fasta=open(args.output,'w')
  for key,value in list_dict.items():
  if args.detail:
  print('>'+key,'['+value[0],value[1]+1,value[2],value[3]+']',file=output_fasta)
  else:
  print('>'+key,file=output_fasta)
  seq=seq_file['>'+value[0]][value[1]:value[2]]
  if value[3]=='+':
  print(seq,file=output_fasta)
  elif value[3]=='-':
  seq=rev(seq)
  print(seq,file=output_fasta)
  output_fasta.close()


  适用上述示例中的测试文件,运行该脚本的方式如下。


  #python3 seq_select.py-h
  python3 seq_select.py-i Bacillus_subtilis.str168.fasta-l list.txt-o gene.fasta--detail
  源码提取链接:https://pan.baidu.com/s/1kUhBTmpDonCskwmpNIJPkA?pwd=ih9n

03.png

  提取码:ih9n

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/128450.html

相关文章

  • 第三代基因测序技术革新 云计算的应用

    摘要:第三代基因测序技术革新云计算的应用一位准妈妈,在怀孕周时,需要做唐氏儿的筛查,传统唐筛的方式准确率低,如果结果显示危险性高,那么准妈妈还需要做羊膜穿刺等进一步检查。未来组目前已经拥有两台第三代基因测序仪,而未来这一数字将增长至五台。 第三代基因测序技术革新 云计算的应用一位准妈妈,在怀孕12-24周时,需要做唐氏儿的筛查,传统唐筛的方式准确率低,如果结果显示危险性高,那么准妈妈还需要做...

    RaoMeng 评论0 收藏0
  • 谷歌推出开源工具DeepVariant,用深度学习识别基因变异

    摘要:今天推出了一个名叫的开源工具,用深度神经网络来从测序数据中快速较精确识别碱基变异位点。今天,团队,联合同属于旗下的生命科学兄弟公司,用了两年多时间,研发出了一个名叫的开源工具,专门用深度神经网络来识别结果中测序数据里这些碱基变异位点。 Google今天推出了一个名叫DeepVariant的开源工具,用深度神经网络来从DNA测序数据中快速较精确识别碱基变异位点。学科研究的革命性进展,特别是基因...

    raledong 评论0 收藏0
  • 【F3使用场景】F3经典使用场景

    摘要:通过选用云主机,基因企业在基因计算环节可以大幅提升产能而普通大众,也能享受成本降低带来的普惠。而客户选用云主机,避免了维护复杂板卡的大量人力物力的投入,缩减了验证平台的维护成本。 摘要: 概括F3经典使用场景 人工智能深度学习客户,推理应用 最近两年,人工智能在全球掀起了巨大的应用热潮,除了互联网巨头,如Google,Facebook,Alibaba之外,涌现出众多的Start up公...

    baiy 评论0 收藏0
  • 云计算和大数据延伸至生命信息领域:生物云计算

    摘要:华为生科云解决方案,由工作流弹性计算云对象云存储线下数据寄送服务四部分组成,为客户提供端到端的解决方案,助力中国科研数据分析,演绎了生物与计算的完美结合。 随着互联网的普及和技术的发展,大数据和云计算已经渗透在人们的生活的各个方面,在金融,零售,能源,交通等领域已经得到广泛应用。而对于生物信息来说,生物的DNA、基因序列、生物芯片等无时无刻不产生新的数据;比如说,DNA测序每年能够产生大约1...

    ethernet 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<