1

我试图重复调用一个函数(特别是 Seurat::DimPlot),其中一个参数是一个命名列表(cells.highlight)。我打算用purrr::imap做打电话。我有一个命名列表,其中列表的每个元素都是一个字符向量。我想为 Seurat::DimPlot 的 cells.highlight 参数创建列表。当我尝试

imap(mylist, ~ DimPlot(seurat_obj, cells.highlight=list(.y=.x), cols="lightgrey", 
  cols.highlight="dodgerblue")  )

该图看起来不错,但不是将变量 .y 替换为列表元素名称,而是将列表元素名称保留为“.y”。(所以在图例中我看到“.y”)。制作 SSCE

dp <- function(name, values){
   list(name = values)
}
dp("a",paste0("a",1:3))
# $name
# [1] "a1" "a2" "a3"

我希望它在哪里

$a
[1] "a1" "a2" "a3"`

我尝试过使用 enquo、as_name、使用 ':='、ensym、quote,但我似乎无法做到正确。我知道你可以用 list[[name]]=... 之类的东西把它分成两行,但因为这是一个更大问题的一部分,我很想学习如何适当地引用和取消引用变量名。

我一直在使用 NSE 时遇到问题,即使在阅读、重新阅读和重新阅读 Hadley Wickhams 的 Advanced-R关于准引用的章节和他的关于评估的章节之后,但似乎所有的部分都在那里,我只是可以不把它们放在一起

4

1 回答 1

2

由于您是用户purrr,您应该使用它set_names来设置列表的名称

imap(mylist, ~ DimPlot(seurat_obj, cells.highlight=set_names(list(.x), .y), cols="lightgrey", 
  cols.highlight="dodgerblue")  )

举个dp例子,这将是

dp <- function(name, values){
  set_names(list(values), name)
}
dp("a",paste0("a",1:3))
# $`a`
# [1] "a1" "a2" "a3"

所以在这种情况下,这真的与非标准评估无关。这只是为工作使用正确的功能。

于 2019-04-29T18:35:52.760 回答