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)
| 归档时间: |
|
| 查看次数: |
1726 次 |
| 最近记录: |