Python在GBFF里提取cds序列怎么实现
Admin 2022-08-04 群英技术资讯 693 次浏览
1、 LOCUS(代码)序列的功能、序列长度、类型、种属来源、录入日期
2、 DEFINITION(说明)所含的生物学意义的总结性描述
3、 ACCESSION(编号)具有唯一性和永久性
4、 VERSION(版本号)检索号、版本号
5、 KEYWORDS(关键词)描述序列,“ . ”表示没有任何描述内容
6、 SOURCE(数据来源)序列来源生物的简称,或分子类型
7、 REFERENCE (文献)与该数据有关的参考文献,按发表时间排名
8、 FEATURES(特性表)描述基因和基因的产物,以及与序列相关的生物学特性,其中包括
9、 ORIGIN(碱基排列顺序)类似于FASTA格式给出了所记录的序列
import re FILE_PATH = './input.gb' OUT_FILE_PATH = './output.fasta' d = {} g = {} tem = [] def con_spl(list_,n = 2): return [list_[i:i + n] for i in range(0, len(list_), n)] with open (FILE_PATH,'r')as f: while True: text_line = f.readline().strip('\t').split() if text_line: if text_line[0] == 'DEFINITION': c = ' '.join(i for i in text_line[2:]) d[c] = [] g[c] = [] print (text_line) elif text_line[0] == 'CDS': cds = re.findall(r"\d+\d*?",text_line[1]) if len(cds) == 2: d[c].append(cds) else: for i in con_spl(cds): d[c].append(i) elif text_line[0] == 'ORIGIN': while text_line[0] != '//': for i in text_line[1:]: tem.append(i) text_line = f.readline().strip('\t').split() e = ''.join(i for i in tem) g[c].append(e) else: pass elif f.readline().strip('\t').split(): continue else: break with open (OUT_FILE_PATH,'w')as f: for i,o in d.items(): G = ''.join(g[I]) p = '' for u in o: u1 = int(u[0]) u2 = int(u[1])+1 p += G[u1:u2] print ('>',i,sep='',file=f) print (p,file=f)
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章给大家分享的是有关python如何批量移动文件的内容,小编觉得是比较实用的,下面就通过一个实例给大家介绍一下,感兴趣的朋友就继续往下看吧。
这篇文章主要为大家详细介绍了Python使用sftp实现上传和下载功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
使用Hadoop进行大数据运算,当数据量极其大时,那么对MapReduce性能的调优重要性不言而喻,尤其是Shuffle过程中的参数配置对作业的总执行时间影响特别大。下面总结一些和MapReduce相关的性能调优方法,主要从五个方面考虑:数据输入、Map阶段、Reduce阶段、Shuffle阶段和其他调优属性。
在Python中,字符串前面我们经常看到会加一些前缀,例如u、r、b、f。这篇文章将带大家简单了解一下字符串前加r(R)或u/(U)的前缀的区别,快来跟随小编一起学习吧
文本给大家介绍的是Python的字符串的内容,详细介绍了字符串的创建,字符串的定义,字符串的操作,具有一定的借鉴价值,有需要的朋友可以参考学习。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008