Повторить n раз элемент между двумя датами и указать даты рядом с ним

Как я могу повторить элемент между двумя датами и указать даты

Входные значения:

Я БЫНачинатьКонец
ST0015 мая 2022 г.15 мая 2022 г.
ТЕ0123 мая 2022 г.25 мая 2022 г.
ТО0116 мая 2022 г.19 мая 2022 г.

Ожидаемый результат:

Я БЫДата
ST0015 мая 2022 г.
ТЕ0123 мая 2022 г.
ТЕ0124 мая 2022 г.
ТЕ0125 мая 2022 г.
ТО0116 мая 2022 г.
ТО0117 мая 2022 г.
ТО0118 мая 2022 г.
ТО0119 мая 2022 г.

Что я делаю прямо сейчас:

на Е2

=ARRAYFORMULA(TRIM(TRANSPOSE(SPLIT(QUERY( REPT(A2:A&"~", if(A2:A="",,C2:C-B2:B+1)),,9^9), "~"))))

в F2 (и перетаскивание ниже)

=countif(E$2:E2,E2)

в G2

=arrayformula(iferror(vlookup(E2:E,A:B,2,0)+F2:F-1))

enter image description here

Есть ли способ сделать это без столбца F?

Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
Четыре эффективных способа центрирования блочных элементов в CSS
Четыре эффективных способа центрирования блочных элементов в CSS
У каждого из нас бывали случаи, когда нам нужно отцентрировать блочный элемент, но мы не знаем, как это сделать. Даже если мы реализуем какой-то...
0
0
25
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

использовать:

=ARRAYFORMULA(QUERY(SPLIT(FLATTEN(IF(DAYS(C2:C, B2:B)>=SEQUENCE(1, 1000, ), 
 IF(A2:A="",,A2:A&"×"&TEXT(B2:B+SEQUENCE(1, 1000, ), "mmm dd e")), )), "×"), 
 "where Col2 is not null", ))

enter image description here

Быстрее:

=ARRAYFORMULA(QUERY(SPLIT(FLATTEN(IF(DAYS(C2:C, B2:B)>=SEQUENCE(1, MAX(C2:C-B2:B+1), ), 
 IF(A2:A="",,A2:A&"×"&TEXT(B2:B+SEQUENCE(1, MAX(C2:C-B2:B+1), ), "mmm dd e")), )), "×"), 
 "where Col2 is not null", ))

whaou, спасибо, Купер! Я пробовал с последовательностью, но не нашел решения. Большой!

Mike Steelson 09.04.2022 14:21

Я удалил формат, чтобы сохранить значения в столбце F. Действительно, с настроенной последовательностью это происходит быстрее.

Mike Steelson 09.04.2022 14:51

есть интересный способ сделать это, который включает использование дополнительного столбца в запросе, с которым вы сравниваете... docs.google.com/spreadsheets/d/…

MattKing 09.04.2022 23:09

Формула аналогична формуле @player0, но мне нравится использовать конечный столбец в качестве «дополнительного» столбца в сконструированном массиве для сравнения с запросом.

Вот образец листа, созданный специально для решения этой задачи, где эту формулу можно найти в A2 на вкладке «Вывод».

=ARRAYFORMULA(QUERY(SPLIT(FLATTEN(Data!A2:A&"|"&Data!B2:B+SEQUENCE(1,MAX(Data!C2:C-Data!B2:B),0)&"|"&Data!C2:C),"|",0,0),"select Col1,Col2 where Col2<=Col3"))

Другие вопросы по теме