У меня есть tibble / dataframe под названием sections
, который я хочу использовать для создания нескольких новых tibbles / dataframe. Я хочу перебрать каждую строку и создать новый тиббл для каждого. Первый столбец содержит имя нового тибла, а второй и третий столбцы содержат индексы для использования в другом тибле, называемом my_text
.
sections <- structure(list(sections = c("cash_and_bank_sweep", "money_market_funds_non-sweep",
"equities"),
begin_row = c(325L, 345L, 357L),
end_row = c(345L, 357L, 384L)),
class = c("tbl_df", "tbl", "data.frame"),
row.names = c(NA, -3L))
> sections
# A tibble: 3 x 3
sections begin_row end_row
<chr> <int> <int>
1 cash_and_bank_sweep 325 345
2 money_market_funds_non-sweep 345 357
3 equities 357 384
set.seed(1)
my_text <- tibble(Strings = sample(letters, size = 1000, replace = TRUE)
> head(my_text)
# A tibble: 6 x 1
Strings
<chr>
1 y
2 d
3 g
4 a
5 b
6 w
Итак, первый тибле, который я хочу создать будет cash_and_bank_sweep
. Вручную я могу создать следующее:
cash_and_bank_sweep <- tibble(Strings = my_text$Strings[sections$begin_row[1]:sections$end_row[1]])
> head(cash_and_bank_sweep)
# A tibble: 6 x 1
Strings
<chr>
1 e
2 n
3 e
4 k
5 k
6 q
Есть ли какой-нибудь способ эффективно сделать это с помощью al oop или другой конструкции?