nest {tidyseurat} | R Documentation |
Nest rows into a list-column of data frames
Description
Nesting creates a list-column of data frames; unnesting flattens it back out into regular columns. Nesting is implicitly a summarising operation: you get one row for each group defined by the non-nested columns. This is useful in conjunction with other summaries that work with whole datasets, most notably models.
Learn more in vignette("nest")
.
Usage
## S3 method for class 'Seurat'
nest(.data, ..., .names_sep = NULL)
Arguments
.data |
A data frame. |
... |
< Specified using name-variable pairs of the form
If not supplied, then :
previously you could write |
.names_sep |
If |
Details
If neither ...
nor .by
are supplied, nest()
will nest all variables,
and will use the column name supplied through .key
.
Value
'tidyseurat_nested'
New syntax
tidyr 1.0.0 introduced a new syntax for nest()
and unnest()
that's
designed to be more similar to other functions. Converting to the new syntax
should be straightforward (guided by the message you'll receive) but if
you just need to run an old analysis, you can easily revert to the previous
behaviour using nest_legacy()
and unnest_legacy()
as follows:
library(tidyr) nest <- nest_legacy unnest <- unnest_legacy
Grouped data frames
df %>% nest(data = c(x, y))
specifies the columns to be nested; i.e. the
columns that will appear in the inner data frame. df %>% nest(.by = c(x, y))
specifies the columns to nest by; i.e. the columns that will remain in
the outer data frame. An alternative way to achieve the latter is to nest()
a grouped data frame created by dplyr::group_by()
. The grouping variables
remain in the outer data frame and the others are nested. The result
preserves the grouping of the input.
Variables supplied to nest()
will override grouping variables so that
df %>% group_by(x, y) %>% nest(data = !z)
will be equivalent to
df %>% nest(data = !z)
.
You can't supply .by
with a grouped data frame, as the groups already
represent what you are nesting by.
Examples
data(pbmc_small)
pbmc_small |>
nest(data=-groups) |>
unnest(data)