Функция для вычисления разницы двух дат в формате лет, месяцев, дней

19.01.24

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

Приведен алгоритм и реализация функции для программного вычисления разницы двух дат (не в запросе).

Доброго времени суток. Недавно на форуме увидел в очередной раз обсуждение кода для вычисления разницы двух дат (не в запросе) для размещения в форме в виде табло: Лет, Месяцев, Дней. Для отображения количества промежутка времени в стаже, контракта, например. Как выражаются мои бухгалтеры: калькулятор. Для "обратного" действия от тоже работает.

В БСП такой функции не обнаружил, с переводом в запрос (там есть нужная функция) получается "громоздко". Захотелось сделать своё, без проверок и условий, что-то более "изящное". Получилось вроде неплохо, обратил внимание, что функция ДобавитьМесяц() работает очень корректно, например при переходе через февраль месяц (начальная дата, например, 30 января, конечная дата - 30 марта). Этим и воспользовался.

Привожу код функции.

Пару слов: обрабатываю в примере два интервала: в русском языке есть два понятия - с/по и с/до! В соответствии с этим обрабатываю конечную дату.

Проверял на платформе 8.3 (8.3.12.1924), но думаю, работать будет везде.

 

PS. Благодаря "бдительности" Gesperid (отдельное спасибо) подкорректировал код + нашел неточность (пометил на примере кода: кто скачивал - исправляйте)

Функция ПолучениеРазницыДат (ДатаС, ДатаПо, ДатаДо)
	Если ДатаПо <> Дата('00010101') Тогда
		ДатаОкон = ДатаПо;
                ДеньКоррекции = 3600*24; //для корректировки даты ПО
	ИначеЕсли ДатаДо <> Дата('00010101') Тогда
		ДатаОкон = ДатаДо;
		ДеньКоррекции = 0;
	Иначе
		НовСообщ = Новый СообщениеПользователю;
		НовСообщ.Текст = "Выберите одну дату";
		НовСообщ.Сообщить();
	КонецЕсли;

	РазницаДатыС = День(КонецМесяца(ДатаС)) - День(ДатаС); //добавление
	КонМесДатыС = КонецМесяца(ДатаС);                         //добавление

		Если ДатаОкон >= ДатаС Тогда 
			ВремГод = 0; ВремМес = 0; ВремДней = 0; 
			НоваяДата = ДобавитьМесяц(КонМесДатыС, 12);      //исправление
			
			Пока НоваяДата <= ДатаОкон + ДеньКоррекции Цикл
				ВремГод = ВремГод + 1;
				НоваяДата = ДобавитьМесяц(НоваяДата, 12);
			КонецЦикла;
			
			ПромДата = ДобавитьМесяц(НоваяДата, - 12); //ввел промежуточную дату после подсчета лет для
                                                                   // корректного перехода февраля месяца, если он есть.
			НоваяДата = ДобавитьМесяц(ПромДата, 1);
			Пока НоваяДата <= ДатаОкон + ДеньКоррекции Цикл
				ВремМес = ВремМес + 1;
				НоваяДата = ДобавитьМесяц(ПромДата, 1 + ВремМес);
			КонецЦикла;
			
			НоваяДата = ДобавитьМесяц(КонМесДатыС, 12*ВремГод + ВремМес);    //исправление
			ВремДней = РазницаДатыС + ?(Год(ДатаОкон + ДеньКоррекции)=Год(НоваяДата), ДеньГода(ДатаОкон + ДеньКоррекции) - ДеньГода(НоваяДата), ДеньГода(КонецГода(НоваяДата)) - ДеньГода(НоваяДата) + ДеньГода(ДатаОкон + ДеньКоррекции)); //добавление
		
			Возврат "" + ВремГод + "/" + ВремМес + "/" + ВремДней;

		Иначе
			НовСообщ = Новый СообщениеПользователю;
			НовСообщ.Текст = "Проверьте формат дат";
			НовСообщ.Сообщить();
		КонецЕсли;
		

КонецФункции

 

См. также

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

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

21.05.2024    20094    dimanich70    81    

144

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

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

1 стартмани

18.03.2024    4089    3    John_d    11    

57

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

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

12.02.2024    18028    atdonya    24    

56

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

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

30.11.2023    5500    ke.92@mail.ru    16    

65

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

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

28.08.2023    14723    YA_418728146    7    

166

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

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

2 стартмани

22.08.2023    3573    56    progmaster    8    

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    18474    171    sapervodichka    112    

135
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Gesperid 2 28.12.23 13:59 Сейчас в теме
Что вы понимаете под разностью дат?
Это сложный вопрос.
Вот вопросы попроще.
* 01.03.2023 - 28.01.23 = ?
* 01.03.2023 - 29.01.23 = ?
* 01.03.2023 - 30.01.23 = ?

Вызывает вопросы:
* Имена и назначение параметров
* Тип и формат возвращаемого значения. Почему строкой и в таком формате?
* Факт валидации входных параметров
* Возврат ошибки через сообщение пользователю

И, честно сказать, изящность функции в целом - под вопросом.
2. user654641_yaga_m 13 29.12.23 18:22 Сейчас в теме
(1)Спасибо за тестирование и анализ кода. Чуть исправил - надеюсь Вы будете "довольны" - Ваши примеры работают...
3. user654641_yaga_m 13 19.01.24 09:07 Сейчас в теме
Коллеги, сорь, нашел ошибку:
"РазницаДатыС = День(КонецМесяца(ДатаС)) - День(ДатаС) + 1;"
исправил на:
"РазницаДатыС = День(КонецМесяца(ДатаС)) - День(ДатаС);"
4. SagittariusA 19.01.24 10:20 Сейчас в теме
В БСП такой функции не обнаружил

Очень странно...

Это не подходит?

ОбщегоНазначенияБПКлиентСервер.РазностьДат


ОбщегоНазначенияУТ.РазностьДат
5. user654641_yaga_m 13 19.01.24 12:43 Сейчас в теме
(4)ДД, у меня другие конфигурации, + может старые БСП...
6. SagittariusA 19.01.24 13:17 Сейчас в теме
(5) возможно. Актуальные БСП можно брать на тут.
Оставьте свое сообщение