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

14.06.14

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

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

Скачать файлы

Наименование Файл Версия Размер
ТаблицаДатЗаПериод(v1).epf
.epf 8,24Kb
45
.epf 1.01 8,24Kb 45 Скачать

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

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

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

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

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

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

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

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


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

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

См. также

GUID в 1С 8.3 - как с ними быть

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

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

12.02.2024    4318    atdonya    22    

41

Переоткрытие внешних обработок

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

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

30.11.2023    3883    ke.92@mail.ru    16    

60

Валидация JSON через XDTO (включая массивы)

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

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

28.08.2023    8561    YA_418728146    6    

139

Печать непроведенных документов для УТ, КА, ERP. Настройка печати по пользователям, документам и печатным формам

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

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

2 стартмани

22.08.2023    2020    21    progmaster    7    

3

Расширение: Быстрые отборы через буфер [Alt+C] Копировать список, [Alt+V] Вставить список, [Ctrl+C] Копировать из файлов

Инструментарий разработчика Универсальные функции Платформа 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    16013    131    sapervodichka    112    

129

Система контроля ведения учета [БСП]

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

В данном материале рассмотрим типовой алгоритм подсистемы контроля учета БСП в конфигурациях на примерах.

18.07.2022    7200    quazare    8    

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

Иначе в случае если начало периода не совпадает с началом интервала, то будет в результат будет попадать лишняя дата (начало интервала), а в целом супер, спасибо за сэкономленное время!)
rusness; mtv:); +2 Ответить
7. ig-efrem 16 16.10.20 14:38 Сейчас в теме
8. pauk7878 12.11.21 02:56 Сейчас в теме
В каком формате нужно передать в функцию эти параметры - НачДата, КонДата, Интервал ?
9. sertrain 23.07.23 20:39 Сейчас в теме
Может спустя 8 лет итоги начали по другому работать, но у меня в результате запроса всего одна группировка с начальной датой
10. ivanleb 05.09.23 16:11 Сейчас в теме
11. Briolin1C 22.11.23 13:14 Сейчас в теме
Оставьте свое сообщение