在R中循环嵌套列表

JHS*_*JHS 6 loops r list lapply

我有一个包含15个级别的巨大嵌套列表.我需要用chr""替换任何级别的空列表.我尝试了lapply循环遍历列表,但它不起作用.有没有简单的方法来做到这一点?

nested_list<-list(a=list(x=list(),y=list(i=list(),j=list(p=list(),q=list()))),b=list())

lapply(nested_list,function(x) if(length(x)==0) "" else x)
Run Code Online (Sandbox Code Playgroud)

lapply仅应用于第一级,如何递归循环整个嵌套列表并执行此操作?

Ran*_*Lai 10

尝试以下递归.

foo <- function(l){
    lapply(l, function(x) if(length(x)==0) "" else foo(x))
}
foo(nested_list)
Run Code Online (Sandbox Code Playgroud)

编辑:一个更好的版本

foo <- function(l){
    lapply(l, function(x) if(is.list(x) && length(x)==0) "" else if(is.list(x)) foo(x) else x)
}
Run Code Online (Sandbox Code Playgroud)