Aha! I haven't thought about it. I really like the approach presented by Bert Gunter in the previous post. It is a good lesson.

I made my previous code a little bit better by building a function that pulls out only the desired component. At this time, the names of sublists are changed as below (i.e. the names of 'A', 'B', 'C' in the example given by Rainer M Krug are changed to 'A', 'Aha', 'alpha' here):

> x1 <- list(A = 11, Aha = 21, alpha = 31)
> x2 <- list(A = 12, Aha = 22, alpha = 32)
> x3 <- list(A = 13, Aha = 23, alpha = 33)
> x4 <- list(A = 14, Aha = 24, alpha = 34)
> y1 <- list(x1 = x1, x2 = x2)
> y2 <- list(x3 = x3, x4 = x4)
> x <- list(f1 = y1, f2 = y2)
>
> extr.1 <- function(x, name){
+   xl <- unlist(x)
+   depth <- sum(unlist(strsplit(names(xl)[1], split="")) == ".") + 1
+ xl[grep(paste("^",name,"$", sep=""), unlist(strsplit(names(xl), ".", fixed=TRUE)))/depth]
+ }
> extr.1(x=x, name="alpha")
f1.x1.alpha f1.x2.alpha f2.x3.alpha f2.x4.alpha
         31          32          33          34
> extr.1(x=x, name="A")
f1.x1.A f1.x2.A f2.x3.A f2.x4.A
     11      12      13      14
> extr.1(x=x, name="a")
named numeric(0)
> extr.1(x=x, name="Aha")
f1.x1.Aha f1.x2.Aha f2.x3.Aha f2.x4.Aha
       21        22        23        24
>

Hm.... this function 'extr.1()' seems to be (much) slower than the function 'extr()'.

Chel Hee Lee

On 01/16/2015 11:34 AM, Bert Gunter wrote:
Chee Hee's approach is both simpler and almost surely more efficient,
but I wanted to show another that walks the tree (i.e. the list)
directly using recursion at the R level to pull out the desired
components. This is in keeping with R's "functional" programming
paradigm and avoids the use of regular expressions to extract the
desired components from the unlist() version.

extr <- function(x,nm){
   if(is.recursive(x)){
     wh <- names(x) %in% nm
     c(x[wh],lapply(x[!wh],extr,nm=nm) )
   } else NULL
}

## The return value contains a bunch of NULLs; so use unlist() to remove them

unlist(extr(x,"A"))
f1.x1.A f1.x2.A f2.x3.A f2.x4.A
      11      12      13      14


I would welcome any possibly "slicker" versions of the above.

Cheers,
Bert

Bert Gunter
Genentech Nonclinical Biostatistics
(650) 467-7374

"Data is not information. Information is not knowledge. And knowledge
is certainly not wisdom."
Clifford Stoll




On Fri, Jan 16, 2015 at 7:23 AM, Chel Hee Lee <chl...@mail.usask.ca> wrote:
This approach may not be fancy as what you are looking for.

xl <- unlist(x)
xl[grep("A", names(xl))]
f1.x1.A f1.x2.A f2.x3.A f2.x4.A
      11      12      13      14


I hope this helps.

Chel Hee Lee

On 01/16/2015 04:40 AM, Rainer M Krug wrote:

Hi

Consider the following variable:

--8<---------------cut here---------------start------------->8---
x1 <- list(
    A = 11,
    B = 21,
    C = 31
)

x2 <- list(
    A = 12,
    B = 22,
    C = 32
)

x3 <- list(
    A = 13,
    B = 23,
    C = 33
)

x4 <- list(
    A = 14,
    B = 24,
    C = 34
)

y1 <- list(
    x1 = x1,
    x2 = x2
)

y2 <- list(
    x3 = x3,
    x4 = x4
)

x <- list(
    f1 = y1,
    f2 = y2
)
--8<---------------cut here---------------end--------------->8---


To extract all fields named "A" from y1, I can do

,----
| > sapply(y1, "[[", "A")
| x1 x2
| 11 12
`----

But how can I do the same for x?

I could put an sapply into an sapply, but this would be less then
elegant.

Is there an easier way of doing this?

Thanks,

Rainer



______________________________________________
R-help@r-project.org mailing list -- To UNSUBSCRIBE and more, see
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide
http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.


______________________________________________
R-help@r-project.org mailing list -- To UNSUBSCRIBE and more, see
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.

______________________________________________
R-help@r-project.org mailing list -- To UNSUBSCRIBE and more, see
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.

Reply via email to