Универсальная функция получения таблицы дат за период. С любым интервалом (день, неделя, месяц, квартал и т.д.)

14.06.14

Разработка - Универсальные функции

Небольшая функция, возвращающая таблицу значений со всеми датами за период. Интервал дат можно задать любой: Секунда, Минута, Час, День, Неделя, Месяц, Квартал, Полугодие, Год.

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
ТаблицаДатЗаПериод(v1).epf
.epf 8,24Kb ver:1.01
46
46 Скачать (1 SM) Купить за 1 850 руб.

При разработке очередного отчета понадобилось получить таблицу дат за период, но с разными интервалами (День, Месяц, Квартал, Год). Поиск готовых решений в интернетене не дал приемлемых результатов. Пришлось разбираться самому. И вот, что из этого получилось.

Универсальная функция получения таблицы дат за период

// Возвращает таблицу значений с датами за период
//
// Параметры:
//  НачДата  - Дата - Начало периода
//  КонДата  - Дата - Конец периода
//  Интервал - Строка - одно из следующих значений:
//             (Секунда, Минута, Час, День, Неделя, Месяц, Квартал, Полугодие, Год)
//
// Возвращаемое значение:
//   Таблица значений с датами за период. Содержит одну колонку "НачИнтервала"
//
Функция ПолучитьТаблицуДатЗаПериод(НачДата, КонДата, Интервал)

   
тзИнтервалов = Новый ТаблицаЗначений;
   
тзИнтервалов.Колонки.Добавить("НачИнтервала", Новый ОписаниеТипов("Дата"));

   
Запрос = Новый Запрос;
   
Запрос.Текст = "ВЫБРАТЬ
    |   НАЧАЛОПЕРИОДА(&НачДата, День) КАК НачИнтервала
    |УПОРЯДОЧИТЬ ПО
    |   НачИнтервала
    |ИТОГИ ПО
    |   НачИнтервала ПЕРИОДАМИ("
+Интервал+", &НачДата, &КонДата)";
   
//Параметры запроса
   
Запрос.УстановитьПараметр("НачДата", НачДата);
   
Запрос.УстановитьПараметр("КонДата", КонДата);

   
Выборка = Запрос.Выполнить().Выбрать(ОбходРезультатаЗапроса.ПоГруппировкам, "НачИнтервала", "ВСЕ");
    Пока
Выборка.Следующий() Цикл
       
НоваяСтрока = тзИнтервалов.Добавить();
       
НоваяСтрока.НачИнтервала = Выборка.НачИнтервала;
    КонецЦикла;

    Возврат 
тзИнтервалов;

КонецФункции
//ПолучитьТаблицуДатЗаПериод()


Для примера прилагаю демонстрационную обработку. В ней можно выбрать Период, Интервал и сгенерировать таблицу Дат. Внешний вид обработки представлен на скриншотах.

Даты даты за период

См. также

Универсальные функции Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Благодаря этим пяти строчкам можно больше не заморачиваться с загрузкой из внешних файлов. Пользуюсь везде, всегда и постоянно.

21.05.2024    23956    dimanich70    81    

147

Универсальные функции Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

Задача: вставить картинку из буфера обмена на форму средствами платформы 1С.

1 стартмани

18.03.2024    4416    3    John_d    11    

57

Универсальные функции Программист Стажер Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Пришлось помучиться с GUID-ами немного, решил поделиться опытом, мало ли кому пригодится.

12.02.2024    23616    atdonya    25    

58

Универсальные функции Программист Платформа 1С v8.3 Бесплатно (free)

На заключительных этапах, когда идет отладка или доработка интерфейса, необходимо много раз переоткрыть внешний объект. Вот один из способов автоматизации этого.

30.11.2023    5942    ke.92@mail.ru    17    

65

WEB-интеграция Универсальные функции Механизмы платформы 1С Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

При работе с интеграциями рано или поздно придется столкнуться с получением JSON файлов. И, конечно же, жизнь заставит проверять файлы перед тем, как записывать данные в БД.

28.08.2023    16146    YA_418728146    8    

170

Пакетная печать Печатные формы Адаптация типовых решений Универсальные функции Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Абонемент ($m)

Расширение для программ 1С:Управление торговлей, 1С:Комплексная автоматизация, 1С:ERP, которое позволяет распечатывать печатные формы для непроведенных документов. Можно настроить, каким пользователям, какие конкретные формы документов разрешено печатать без проведения документа.

2 стартмани

22.08.2023    4061    66    progmaster    9    

4

Инструментарий разработчика Универсальные функции Платформа 1С v8.3 Конфигурации 1cv8 1С:Розница 2 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Абонемент ($m)

Копирует в буфер значения из списков, из ячеек отчетов, таблиц, настроек списков, других отборов и вставляет в выбранную настройку отбора. Работает с Объект не найден. Работает как в одной так и между разными базами 1С. Использует комбинации [Alt+C] Копировать список, [Alt+V] Вставить список. Также для копирования данных используется стандартная [Ctrl+C] (например из открытого xls, mxl, doc и т.п. файла скопировать список наименований)

1 стартмани

13.10.2022    18989    176    sapervodichka    112    

136
Отзывы
13. Tapochki-tmn 43 06.11.24 09:33 Сейчас в теме
(12) Все работает, только не в консоли запросов, а именно с

Выборка = Запрос.Выполнить().Выбрать(ОбходРезультатаЗапроса.ПоГруппировкам, "НачИнтервала", "ВСЕ");

Третий параметр "ВСЕ" имеет решающее значение:

https://its.1c.ru/db/metod8dev/content/2660/hdoc

и да, правильно внесли корректировку про:

| НАЧАЛОПЕРИОДА(&НачДата, "+Интервал+") КАК НачИнтервала
Остальные комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. monkbest 114 25.06.14 08:51 Сейчас в теме
Статья очень полезная. Сама обработка наверное тут не нужна, а вот кусок запроса, который формирует таблицу дата - круто. Раньше всегда решал задачу получения таблицы дат за период обращением к производственному календарю, соответсвенно все зависило от его заполненности. А тут, оказывается, можно без обращения к данным сформировать таблицу дат. Уже столько запросов в своей жизни накатал, но про итоги периодами узнал впервые, век живи, век учись))
2. Программулькин 301 26.06.14 04:34 Сейчас в теме
какая область применения?
3. ignor 237 09.10.14 09:24 Сейчас в теме
Можно утащить к своей статье Ваш вариант заполнения таблицы
http://1cniku.ru/Articles/regqery.html#RegQuery
4. mtv:) 1028 09.10.14 10:32 Сейчас в теме
(3) ignor, Утащить можно :), пользуйтесь на здоровье.
5. agent00mouse 257 22.05.18 20:09 Сейчас в теме
А если хочется этот же результат но во временную таблицу в скд да ещё и с произвольным шагом в днях?
6. VKuser260537212 22.02.19 09:29 Сейчас в теме
все отлично, но вместо:
"| НАЧАЛОПЕРИОДА(&НачДата, День) КАК НачИнтервала"
надо
"| НАЧАЛОПЕРИОДА(&НачДата, "+Интервал+") КАК НачИнтервала"

Иначе в случае если начало периода не совпадает с началом интервала, то будет в результат будет попадать лишняя дата (начало интервала), а в целом супер, спасибо за сэкономленное время!)
rusness; mtv:); +2 Ответить
7. ig-efrem 22 16.10.20 14:38 Сейчас в теме
8. pauk7878 12.11.21 02:56 Сейчас в теме
В каком формате нужно передать в функцию эти параметры - НачДата, КонДата, Интервал ?
9. sertrain 23.07.23 20:39 Сейчас в теме
Может спустя 8 лет итоги начали по другому работать, но у меня в результате запроса всего одна группировка с начальной датой
user1027191; uralkit@uralkit.ru; kassbar; +3 Ответить
10. ivanleb 05.09.23 16:11 Сейчас в теме
11. Briolin1C 22.11.23 13:14 Сейчас в теме
12. slauter77 20 06.09.24 11:28 Сейчас в теме
Не работает так больше, 1с прикрыла лавочку :(
13. Tapochki-tmn 43 06.11.24 09:33 Сейчас в теме
(12) Все работает, только не в консоли запросов, а именно с

Выборка = Запрос.Выполнить().Выбрать(ОбходРезультатаЗапроса.ПоГруппировкам, "НачИнтервала", "ВСЕ");

Третий параметр "ВСЕ" имеет решающее значение:

https://its.1c.ru/db/metod8dev/content/2660/hdoc

и да, правильно внесли корректировку про:

| НАЧАЛОПЕРИОДА(&НачДата, "+Интервал+") КАК НачИнтервала
Оставьте свое сообщение