Avi,

The code generates data for each day of observation. For each day I want to 
generate the number of subjects exposed to a value at, or above, a toxic 
cutpoint. The table below shows an example of the information I want to 
capture. The format of the output is of minor importance. What is important is 
that I get the data from my code. Once I get the data I can work on formatting 
it so it looks nice.

Date    Variable                                       Cutpoint
1/2/2020        Cutpoint Value            0.1   0.2       0.3    0.4
1/2/2020        Number  of Subjects     100       50    10        2
1/3/2020        Cutpoint Value            0.1     0.2    0.3     0.4
1/3/2020        Number  of Subjects       34      22     11      0
1/4/2020        Cutpoint Value            0.1    0.2     0.3     0.4
1/4/2020        Number  of Subjects      200     70     340      40

The table would look better if I could send this email in html format, but I 
believe R help will reject formatted email.

Thank you,
John




John David Sorkin M.D., Ph.D.
Professor of Medicine, University of Maryland School of Medicine;
Associate Director for Biostatistics and Informatics, Baltimore VA Medical 
Center Geriatrics Research, Education, and Clinical Center;
Former PI Biostatistics and Informatics Core, University of Maryland School of 
Medicine Claude D. Pepper Older Americans Independence Center;
Senior Statistician University of Maryland Center for Vascular Research;

Division of Gerontology, Geriatrics and Palliative Medicine,
10 North Greene Street
GRECC (BT/18/GR)
Baltimore, MD 21201-1524
Cell phone 443-418-5382





________________________________________
From: [email protected] <[email protected]>
Sent: Thursday, June 4, 2026 6:30 PM
To: 'Rui Barradas'; Sorkin, John; 'R-help'
Subject: RE: [R] Convert R object to a data frame

It would help, John, if we understood what the resultant data.frame should look 
like.
The structure looks like it contains nested lists including a list of 4 
containing 4 lists of 2.

The contents range from int to num.

In a standard data.frame, you might want eight columns per row and would end up 
with four rows.

You can now make data.frames CAREFULLY in which a column can contain something 
complex such as a list or the output of a statistical function. So, four 
columns each containing a list of 2 columns can be done.

Since you have a very specific data structure in mind, conversions could be 
straightforward or not.

Here is a simpleminded attempt to replicate your first structure to generate 
one row that unexpectedly does something a bit different:

myRow <-
  data.frame(
    alpha = list(criticalvalue=0.1, NumPeopleExposed=0),
    beta  = list(criticalvalue=0.2, NumPeopleExposed=0),
    gamma = list(criticalvalue=0.3, NumPeopleExposed=0),
    delta = list(criticalvalue=0.4, NumPeopleExposed=0)
  )

Note you could have initialized this from the other data structure by putting 
in references to those values instead of my constants BUT the goal was to see 
what it made and, well, it is not as expected:

> myRow
  alpha.criticalvalue alpha.NumPeopleExposed beta.criticalvalue 
beta.NumPeopleExposed gamma.criticalvalue
1                 0.1                      0                0.2                 
    0                 0.3
  gamma.NumPeopleExposed delta.criticalvalue delta.NumPeopleExposed
1                      0                 0.4                      0
> nrow(myRow)
[1] 1
> ncol(myRow)
[1] 8
> names(myRow)
[1] "alpha.criticalvalue"    "alpha.NumPeopleExposed" "beta.criticalvalue"     
"beta.NumPeopleExposed"
[5] "gamma.criticalvalue"    "gamma.NumPeopleExposed" "delta.criticalvalue"    
"delta.NumPeopleExposed"

You need to protect a sub-list from base R with something like the I() function:

Is this version better?

myRow <-
  data.frame(
    alpha = I(list(criticalvalue=0.1, NumPeopleExposed=0)),
    beta  = I(list(criticalvalue=0.2, NumPeopleExposed=0)),
    gamma = I(list(criticalvalue=0.3, NumPeopleExposed=0)),
    delta = I(list(criticalvalue=0.4, NumPeopleExposed=0))
  )

> myRow
                 alpha beta gamma delta
criticalvalue      0.1  0.2   0.3   0.4
NumPeopleExposed     0    0     0     0
> nrow(myRow)
[1] 2
> ncol(myRow)
[1] 4
> names(myRow)
[1] "alpha" "beta"  "gamma" "delta"

Well, my one row now seems to be two rows with four per row.

> myRow$alpha
$criticalvalue
[1] 0.1

$NumPeopleExposed
[1] 0

> myRow$alpha$criticalvalue
[1] 0.1
> myRow$alpha$NumPeopleExposed
[1] 0

This seems to get you some of what you want. Something may be off as it should 
not be two rows.

I would suggest you can possibly find a solution in base R but my experience 
has been using various tidyverse functions as in dplyr to construct and use 
these embedded things.

Do note the above are examples of making a single row and as mentioned, you may 
want to combine multiple ones using various techniques such as rbind and cbind.





-----Original Message-----
From: R-help <[email protected]> On Behalf Of Rui Barradas via R-help
Sent: Thursday, June 4, 2026 5:19 PM
To: Sorkin, John <[email protected]>; R-help <[email protected]>
Subject: Re: [R] Convert R object to a data frame

Às 21:57 de 04/06/2026, Sorkin, John escreveu:
> I have an R object created lapply function within a by a by function
>
>       results_by_date <- by(
>         data,
>          data[,"Date"],
>          function(subdata) {
>            lapply(
>            alertlevels,
>            check_cutpoints2,
>            data=subdata,
>            mycolumn=column
>            )
>          }
>       )
>
> which has the following structure
>
> $ 2020-08-14:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 0
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 0
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 0
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 0
>   $ 2020-08-15:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 1
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 0
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 0
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 0
>   $ 2020-08-16:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 15
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 6
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 6
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 6
>   $ 2020-08-17:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 58
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 20
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 7
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 2
>   $ 2020-08-18:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 79
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 45
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 16
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 6
>   $ 2020-08-19:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 187
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 100
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 61
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 38
>   $ 2020-08-20:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 121
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 31
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 13
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 4
>   $ 2020-08-21:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 17
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 8
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 5
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 3
>   $ 2020-08-22:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 35
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 12
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 6
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 2
>   $ 2020-08-23:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 32
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 15
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 8
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 4
>   $ 2020-08-24:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 15
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 5
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 1
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 0
>   $ 2020-08-25:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 43
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 26
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 13
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 5
>   $ 2020-08-26:List of 4
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.1
>    .. ..$ NumPeopleExposed: int 0
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.2
>    .. ..$ NumPeopleExposed: int 0
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.3
>    .. ..$ NumPeopleExposed: int 0
>    ..$ :List of 2
>    .. ..$ criticalvalue   : num 0.4
>    .. ..$ NumPeopleExposed: int 0
>   - attr(*, "dim")= int 13
>   - attr(*, "dimnames")=List of 1
>    ..$ data[, "Date"]: chr [1:13] "2020-08-14" "2020-08-15" "2020-08-16" 
> "2020-08-17" ...
>   - attr(*, "call")= language by.data.frame(data = data, INDICES = data[, 
> "Date"], FUN = function(subdata) {     lapply(alertlevels, check_cutp| 
> __truncated__ ...
>   - attr(*, "class")= chr "by"
> NULL
>
> I would like to convert the object to a dataframe. Can anyone suggest how I 
> might accomplish this task?
>
> Thank you,
> John
>
> John David Sorkin M.D., Ph.D.
> Professor of Medicine, University of Maryland School of Medicine;
> Associate Director for Biostatistics and Informatics, Baltimore VA Medical 
> Center Geriatrics Research, Education, and Clinical Center;
> Former PI Biostatistics and Informatics Core, University of Maryland School 
> of Medicine Claude D. Pepper Older Americans Independence Center;
> Senior Statistician University of Maryland Center for Vascular Research;
>
> Division of Gerontology, Geriatrics and Palliative Medicine,
> 10 North Greene Street
> GRECC (BT/18/GR)
> Baltimore, MD 21201-1524
> Cell phone 443-418-5382
>
>
>
> ______________________________________________
> [email protected] mailing list -- To UNSUBSCRIBE and more, see
> https://stat.ethz.ch/mailman/listinfo/r-help
> PLEASE do read the posting guide https://www.r-project.org/posting-guide.html
> and provide commented, minimal, self-contained, reproducible code.
Hello,

The problem is that you have a lapply() nested in by(), so you will have
to rbind twice.
It seems that


results_by_date <- by(
   data,
   data[,"Date"],
   function(subdata) {
     lapply(
       alertlevels,
       check_cutpoints2,
       data=subdata,
       mycolumn=column
     ) |> do.call(rbind, args = _)
   }
) |> do.call(rbind, args = _)


can solve it.
Can you post the output of dput(results_by_date[1:2]) ?

Hope this helps,

Rui Barradas

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

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

Reply via email to