前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >qiime2+lefse的n个解决方案

qiime2+lefse的n个解决方案

作者头像
用户1075469
发布2024-01-15 17:56:31
2020
发布2024-01-15 17:56:31
举报
文章被收录于专栏:科技记者科技记者

qiime2 有自带的差异分析工具的(composition ancom),可是,大家已经习惯了一直用的 lefse,于是,把 qiime2 的结果导出进行 lefse 分析,在某种程度上就是一个“刚需”啦!在希望 qiime2 官方或者 lefse 官方做一个 q2-lefse 之前,我们的解决方案有哪几个呢?这里分享下我找到的几个,欢迎补充。

1. dokdo[1]模块

使用 QIIME2 进行微生物组测序分析的 Python 模块。看起来是个台湾同胞写的,最近一次更新在两年前。文档在这里--dokdo documentation--lefse[2]

为了使用 LEfSe,需要打开两个终端窗口:一个用于您通常的 QIIME 2 环境,另一个用于运行 LEfSe。对于后者,应该创建一个新的 conda 环境并安装 LEfSe,如下所述:

  • 运行 QIIME 2 和 Dokdo: 安装好 qiime(略)
代码语言:javascript
复制
# 安装dokdo
git clone https://github.com/sbslee/dokdo
cd dokdo
pip install .
# 激活环境
conda activate qiime2-2020.8
  • 运行 LEfSe(如果选择 Galaxy 在线分析,不需要安装):
代码语言:javascript
复制
conda create -n lefse -c conda-forge python=2.7.15
conda activate lefse
conda install -c bioconda -c conda-forge lefse

设置好两个终端之后,可以从 QIIME 2 特性表中为 LEfSe 创建一个输入文件。以“Moving Pictures”教程为例(在 QIIME 2 终端下运行)。

代码语言:javascript
复制
dokdo prepare-lefse \
-t data/moving-pictures-tutorial/table.qza \
-x data/moving-pictures-tutorial/taxonomy.qza \
-m data/moving-pictures-tutorial/sample-metadata.tsv \
-o output/Useful-Information/input_table.tsv \
-c body-site \
-u subject \
-w "[body-site] IN ('tongue', 'gut', 'left palm')"

然后,就可以选择使用 Galaxy 或者本地进行分析啦!这个方法最早是在这里看到的,github 上竟然没有搜索到。尋找生物標記(Biomarker) LEfSe + dokdo[3]

qiime2 论坛的方法qiime2 to LEfSe[4]

Lefse after QIIME2[5]为 LEfSe 准备 Qiime2 文件:

  • 将 table.gza 折叠到 L6 级别qiime taxa collapse --i-table table.qza --o-collapsed-table collapse.table.qza --p-level 6 --i-taxonomy taxonomy.qza
  • 计算折叠表的相对频率(您得到的不是计数,而是相对丰度)

qiime feature-table relative-frequency --i-table collapse.table.qza --o-relative-frequency-table collapse.frequency.table.qza --output-dir collapse.frequency/

导出 BIOM 文件

qiime tools export collapse.frequency.table.qza --output-dir collapse.frequency/

  • 或者将 BIOM 转换为文本文件(用于 LEFSE 比较)

biom convert \ -i collapse.frequency.table.biom -o collapse.frequency.table.txt --header-key “taxonomy” --to-tsv

您需要为 LEfSe 格式化文本文件。这意味着,根据您是否有类或子类,您必须在文件顶部添加 2-3 行。第 1 行需要是您的类,第 2 行需要是您的子类,第 3 行将是您的全部 “;”,在整个分类中必须更改为 “|”。

易生信流程提供的方法

EasyAmplicon/pipeline.sh at master · YongxinLiu/EasyAmplicon (github.com)[6]

代码语言:javascript
复制
## LEfSe输入文件准备

    ### 3.1. 命令行生成文件
    # 可选命令行生成输入文件
    Rscript ${db}/script/format2lefse.R -h
    mkdir -p result/lefse
    # threshold控制丰度筛选以控制作图中的枝数量
    Rscript ${db}/script/format2lefse.R --input result/otutab.txt \
      --taxonomy result/taxonomy.txt --design result/metadata.txt \
      --group Group --threshold 0.4 \
      --output result/lefse/LEfSe

    ### 3.2 Rmd生成输入文件(可选)
    #1. result目录中存在otutab.txt, metadata.txt, taxonomy.txt三个文件;
    #2. Rstudio打开EasyAmplicon中format2lefse.Rmd,另存至result目录并Knit生成输入文件和可重复计算网页;

这三种方法,相比手动处理,还是多了些方便的,减少了出错的可能,欢迎交流,你用的是哪种呀!

参考资料

[1]

dokdo: https://github.com/sbslee/dokdo

[2]

dokdo documentation--lefse: https://dokdo.readthedocs.io/en/latest/useful_information.html#lefse

[3]

尋找生物標記(Biomarker) LEfSe + dokdo: https://ithelp.ithome.com.tw/articles/10312346?sc=rss.qu

[4]

qiime2 to LEfSe: https://forum.qiime2.org/t/qiime2-to-lefse/13132/3

[5]

Lefse after QIIME2: https://forum.qiime2.org/t/lefse-after-qiime2/4496/8

[6]

EasyAmplicon/pipeline.sh at master · YongxinLiu/EasyAmplicon (github.com): https://github.com/YongxinLiu/EasyAmplicon/blob/master/pipeline.sh

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2024-01-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 微因 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. dokdo[1]模块
  • qiime2 论坛的方法qiime2 to LEfSe[4]
  • 导出 BIOM 文件
    • 易生信流程提供的方法
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档