首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >lapply和BioMart的另一个问题

lapply和BioMart的另一个问题
EN

Stack Overflow用户
提问于 2018-04-26 19:44:36
回答 1查看 47关注 0票数 0

我最近问了一个关于lapply的问题,但现在我改变了方法,遇到了更多我无法解决的问题。

这是我遇到问题的代码:

加载biomaRt

代码语言:javascript
复制
library(biomaRt)

让hsapiens mart

代码语言:javascript
复制
ensembl_hsapiens <- useMart("ensembl", 
                        dataset = "hsapiens_gene_ensembl")

然后我提取人类的基因:

代码语言:javascript
复制
hsapien_PC_genes <- getBM(attributes = c("ensembl_gene_id", "external_gene_name"), 
                      filters = "biotype", 
                      values = "protein_coding", 
                      mart = ensembl_hsapiens)

ensembl_gene_ID <- hsapien_PC_genes$ensembl_gene_id

设置物种向量

代码语言:javascript
复制
species <- c("mmusculus", "ggallus")

这一切都像预期的那样工作,我在使用lapply时遇到了问题

代码语言:javascript
复制
all_homologues <- lapply(species, function(s) getBM(attributes = c("ensembl_gene_id", 
                                                               "external_gene_name", 
                                                               get(paste0(s, "_homolog_ensembl_gene")), 
                                                               get(paste0(s, "_homolog_associated_ensembl_gene")), 
                                                               filters = "ensembl_gene_id", 
                                                               values = c(ensembl_gene_ID), 
                                                               mart = ensembl_hsapiens)))

我得到了错误消息:

代码语言:javascript
复制
 Error in martCheck(mart) : 
  You must provide a valid Mart object. To create a Mart object use the function: useMart.  Check ?useMart for more information.

代码的工作方式如下所示:

代码语言:javascript
复制
all_homologues <- getBM(attributes = c("ensembl_gene_id", "external_gene_name",  
                               "mmusculus_homolog_ensembl_gene", 
                               "mmusculus_homolog_associated_gene_name"),
                           filters = "ensembl_gene_id",
                           values = c(ensembl_gene_ID),
                           mart = ensembl_hsapiens)

但是我有许多物种,所以我希望能够使用一小段代码来提取物种的同源,而不是必须为每个物种重写所有同源。

我认为我用lapply做错了什么,因为在不使用lapply的情况下,mart可以很好地工作。

我之前的问题:Issue with lapply using biomart

EN

回答 1

Stack Overflow用户

发布于 2018-04-26 20:47:56

在尝试过它之后,我通过使用以下命令设法让它正常工作:

代码语言:javascript
复制
all_homologues <- lapply(species, function(s) getBM(attributes = c("ensembl_gene_id", 
                                                               "external_gene_name", 
                                                               paste0(s, c("_homolog_ensembl_gene",
                                                                           "_homolog_associated_gene_name"))),
                                                filters = "ensembl_gene_id",
                                                values = c(ensembl_gene_ID),
                                                mart = ensembl_hsapiens))

虽然我不是很确定为什么?

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50042154

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档