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

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С 8.3.24)

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

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

1 стартмани

18.03.2024    2976    2    John_d    11    

56

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

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

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

12.02.2024    5349    atdonya    22    

52

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

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

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

30.11.2023    4193    ke.92@mail.ru    16    

62

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

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

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

28.08.2023    9684    YA_418728146    6    

146

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

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

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

2 стартмани

22.08.2023    2326    28    progmaster    8    

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    16484    144    sapervodichka    112    

130

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

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

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

18.07.2022    7411    quazare    8    

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

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

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

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


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