If I add a new row to the ìris
dataset with:
iris <- as_tibble(iris)
> iris %>%
add_row(.before=0)
# A tibble: 151 × 5
Sepal.Length Sepal.Width Petal.Length Petal.Width Species
<dbl> <dbl> <dbl> <dbl> <chr>
1 NA NA NA NA <NA> <--- Good!
2 5.1 3.5 1.4 0.2 setosa
3 4.9 3.0 1.4 0.2 setosa
It works. So, why can't I add a new row on top of each "subset" with:
iris %>%
group_by(Species) %>%
add_row(.before=0)
Error: is.data.frame(df) is not TRUE
If you want to use a grouped operation, you need
do
like JasonWang described in his comment, as other functions likemutate
orsummarise
expect a result with the same number of rows as the grouped data frame (in your case, 50) or with one row (e.g. when summarising).As you probably know, in general
do
can be slow and should be a last resort if you cannot achieve your result in another way. Your task is quite simple because it only involves adding extra rows in your data frame, which can be done by simple indexing, e.g. look at the output ofiris[NA, ]
.What you want is essentially to create a vector
(since the first group is in rows 1 to 50, the second one in 51 to 100 and the third one in 101 to 150).
The result is then
iris[indices, ]
.A more general way of building this vector uses
group_indices
.(
map
comes frompurrr
which I assume you have loaded as you have tagged this withtidyverse
).