I have two lists, whose elements have partially overlapping names, which I need to merge/combine together into a single list, element by element:
> lst1 <- list(integers=c(1:7), letters=letters[1:5],
                words=c("two", "strings"))
> lst2 <- list(letters=letters[1:10], booleans=c(TRUE, TRUE, FALSE, TRUE),
                words=c("another", "two"), floats=c(1.2, 2.4, 3.8, 5.6))
> lst1
$integers
[1] 1 2 3 4 5 6 7
$letters
[1] "a" "b" "c" "d" "e"
$words
[1] "two"     "strings"
> lst2
$letters
 [1] "a" "b" "c" "d" "e" "f" "g" "h" "i" "j"
$booleans
[1]  TRUE  TRUE FALSE  TRUE
$words
[1] "another" "two"    
$floats
[1] 1.2 2.4 3.8 5.6
I tried using mapply, which basically combines the two lists by index (i.e.: "[["), while I need to combine them by name (i.e.: "$"). In addition, since the lists have different lengths, the recycling rule is applied (with rather unpredictable results).
> mapply(c, lst1, lst2)
$integers
 [1] "1" "2" "3" "4" "5" "6" "7" "a" "b" "c" "d" "e" "f" "g" "h" "i" "j"
$letters
[1] "a"     "b"     "c"     "d"     "e"     "TRUE"  "TRUE"  "FALSE" "TRUE" 
$words
[1] "two"     "strings" "another" "two"    
$<NA>
 [1] 1.0 2.0 3.0 4.0 5.0 6.0 7.0 1.2 2.4 3.8 5.6
Warning message:
In mapply(c, lst1, lst2) :
  longer argument not a multiple of length of shorter
As you might imagine, what I'm looking for is:
$integers
[1] 1 2 3 4 5 6 7
$letters
[1] "a" "b" "c" "d" "e" "a" "b" "c" "d" "e" "f" "g" "h" "i" "j"
$words
[1] "two"     "strings"   "another" "two"
$booleans
[1]  TRUE  TRUE FALSE  TRUE
$floats
[1] 1.2 2.4 3.8 5.6
Is there any way to achieve that? Thank you!
 
     
     
     
     
    