使用Python ete3包快速大批量地寻找物种的NCBI Taxonomy分类的完整信息(物种名和Taxid可进行相互转换)

本文主要是介绍使用Python ete3包快速大批量地寻找物种的NCBI Taxonomy分类的完整信息(物种名和Taxid可进行相互转换),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ete全称为Environment for Tree Exploration,直译就是树探索环境,此工具可以直接在终端输入
pip install ete3 进行安装即可。ete包主要功能与构建系统发生树有关,若是有相关需求可以查看其介绍文档,地址:The ETE tutorial。我主要使用到了其中的分类工具,即处理NCBI 的Taxonomy数据库的工具。此工具用于物种信息和分类号的转换十分简便,使用时是根据NCBI的最新分类文件来运作的,因此分类信息十分可靠。

目录

        • 下载升级数据库
        • NCBITaxa.get_rank()
        • NCBITaxa.get_lineage()
        • NCBITaxa.get_taxid_translator()
        • NCBITaxa.get_name_translator()
        • NCBITaxa.get_descendant_taxa()
        • 叮!


下载升级数据库

ete3使用NCBI 的Taxonomy数据,因此需要首次使用时需要先下载数据。在应用中主要用到的是ete3包的NCBITaxa模块。首次使用NCBITaxa模块时会检测是否有分类数据存在,没有的话会自动下载。长期未更新时可以直接使用升级选项获取最新的分类数据。即:

from ete3 import NCBITaxa                       # 导入此模块
ncbi = NCBITaxa()
ncbi.update_taxonomy_database()                 # 升级

运行命令后显示如下,此文件taxdump.tar.gz来自于NCBI,网址为:https://ftp.ncbi.nih.gov/pub/taxonomy/

在这里插入图片描述等待下载结束即可(可能下载速度有点慢)。这样准备工作就OK啦。

NCBITaxa.get_rank()

用于获得输入的各个Taxid之间的按照分类单位(即界门纲目科属种等)大小进行排列的顺序,例:

from ete3 import NCBITaxa
ncbi = NCBITaxa()
print(ncbi.get_rank([93061,9443,1282,190485]))

结果:在这里插入图片描述

NCBITaxa.get_lineage()

用于获取输入Taxid代表的物种的完整分类信息,结果为一连串的Taxid号,例:

from ete3 import NCBITaxa
ncbi = NCBITaxa()
print(ncbi.get_lineage(294))

结果:
在这里插入图片描述

NCBITaxa.get_taxid_translator()

用于将Taxid转换为物种名或者对应的分类单位名,输入为列表形式。例:

from ete3 import NCBITaxa
ncbi = NCBITaxa()
print(ncbi.get_taxid_translator([9606]))

结果:
在这里插入图片描述

NCBITaxa.get_name_translator()

用于将物种名或者分类单位名转换为Taxid,输入为列表形式。例:

from ete3 import NCBITaxa
ncbi = NCBITaxa()
print(ncbi.get_name_translator(['Lactococcus lactis subsp. lactis']))

结果:
在这里插入图片描述

NCBITaxa.get_descendant_taxa()

用于获取某分类单位所包含之后的各后代名,例:

from ete3 import NCBITaxa
ncbi = NCBITaxa()
print(ncbi.get_descendant_taxa('Homo'))

结果:在这里插入图片描述
因此根据上述所有方法,若要根据某物种名获取物种的完整分类信息,那么可以首先使用get_name_translator()获取物种的分类id,再利用get_lineage()获取完整的分类信息的Taxid,最后使用NCBITaxa.get_taxid_translator()将Taxid批量转换为物种名即可。

例如若有如下这些物种待分类:

在这里插入图片描述
根据这些物种名寻找其分类信息,可采用如下代码:

from ete3 import NCBITaxa
ncbi = NCBITaxa()with open('22.txt','r',encoding='UTF-8') as f:for line in f.readlines():line = line.strip()name2taxid = ncbi.get_name_translator([line])for value in name2taxid.values():b = str(name2taxid.values()).strip('dict_values([])')lineage = ncbi.get_lineage(b)names = ncbi.get_taxid_translator(lineage)list = []for taxid in lineage:list.append(names[taxid])print(list)

结果太长,此处仅展示2条:
[‘root’, ‘cellular organisms’, ‘Bacteria’, ‘Terrabacteria group’, ‘Firmicutes’, ‘Bacilli’, ‘Lactobacillales’, ‘Streptococcaceae’, ‘Lactococcus’, ‘Lactococcus lactis’, ‘Lactococcus lactis subsp. lactis’]
[‘root’, ‘cellular organisms’, ‘Bacteria’, ‘Terrabacteria group’, ‘Firmicutes’, ‘Bacilli’, ‘Bacillales’, ‘Staphylococcaceae’, ‘Staphylococcus’, ‘Staphylococcus epidermidis’]
可以看到这样分类出的结果是很准确的,因此此工具可以用于分类或其他用途。

叮!

参考:Dealing with the NCBI Taxonomy database
参考:https://zhuanlan.zhihu.com/p/59757585

这篇关于使用Python ete3包快速大批量地寻找物种的NCBI Taxonomy分类的完整信息(物种名和Taxid可进行相互转换)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/408997

相关文章

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验

C#实现将Excel表格转换为图片(JPG/ PNG)

《C#实现将Excel表格转换为图片(JPG/PNG)》Excel表格可能会因为不同设备或字体缺失等问题,导致格式错乱或数据显示异常,转换为图片后,能确保数据的排版等保持一致,下面我们看看如何使用C... 目录通过C# 转换Excel工作表到图片通过C# 转换指定单元格区域到图片知识扩展C# 将 Excel

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

QT进行CSV文件初始化与读写操作

《QT进行CSV文件初始化与读写操作》这篇文章主要为大家详细介绍了在QT环境中如何进行CSV文件的初始化、写入和读取操作,本文为大家整理了相关的操作的多种方法,希望对大家有所帮助... 目录前言一、CSV文件初始化二、CSV写入三、CSV读取四、QT 逐行读取csv文件五、Qt如何将数据保存成CSV文件前言

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Qt中QUndoView控件的具体使用

《Qt中QUndoView控件的具体使用》QUndoView是Qt框架中用于可视化显示QUndoStack内容的控件,本文主要介绍了Qt中QUndoView控件的具体使用,具有一定的参考价值,感兴趣的... 目录引言一、QUndoView 的用途二、工作原理三、 如何与 QUnDOStack 配合使用四、自

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4: