如何从不同的文件中提取相同的数据

问题描述

为了从 qiime2 工件中提取频率表并将其写入 tsv 输出,您必须:

rel_freq_table <- read_qza("05.TaxonomyClassification/rel_freq/1_rel_freq_table.qza")
rel_freq_table <- data.frame(rel_freq_table$data)
rel_freq_table <-  setDT(rel_freq_table,keep.rownames = TRUE )
colnames(rel_freq_table)[1]<- c( "Feature.ID" )
write.table(rel_freq_table,file = "1_rel_freq_table.tsv",row.names = FALSE,dec = ",")

现在,我有七个 qiime2 工件

rel_freqs <- c("05.TaxonomyClassification/rel_freq/1_rel_freq_table.qza","05.TaxonomyClassification/rel_freq/2_rel_freq_table.qza","05.TaxonomyClassification/rel_freq/3_rel_freq_table.qza","05.TaxonomyClassification/rel_freq/4_rel_freq_table.qza","05.TaxonomyClassification/rel_freq/5_rel_freq_table.qza","05.TaxonomyClassification/rel_freq/6_rel_freq_table.qza","05.TaxonomyClassification/rel_freq/7_rel_freq_table.qza")

我想自动化这个过程,所以我只需要运行一次命令。我尝试过循环和 lapply 但没有运气,有人知道吗?

解决方法

您可以编写一个函数并使用 lapply 将其应用到每个文件:

read_qiime2_write_tsv <- function(filename) {
  rel_freq_table <- read_qza(filename)
  rel_freq_table <- data.frame(rel_freq_table$data)
  rel_freq_table <-  setDT(rel_freq_table,keep.rownames = TRUE )
  colnames(rel_freq_table)[1]<- c( "Feature.ID" )
  write.table(rel_freq_table,file = paste0(tools::file_path_sans_ext(basename(filename)),'.tsv'),row.names = FALSE,dec = ",")
}

lapply(rel_freqs,read_qiime2_write_tsv)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...