1с проверить дату на вхождение в период
Дата — один из примитивных типов данных в системе 1С:Предприятие. Дата всегда имеет формат год, месяц, день, час, минута, секунда. Таким образом, переменная типа дата содержит не только дату, но и время.
Одной из первых моих статей в этой рубрике была небольшая шпаргалка по работе с датами, но о датах в запросах там было написано очень мало. В запросах 1С с датами приходится работать довольно часто, особенно когда запрос строится к объектам метаданных в которых содержится периодическая информация. Как правило это регистры (сведений, накопления, расчета, бухгалтерии).
Функция Год
Функция Год() возвращает целое число – год даты. Например, выберем все заказы покупателя оформленные с 1 января 2016 года
Функция Квартал
Возвращает номер квартала даты (целочисленное значение от 1 до 4)
Предположим, в ЗаказПокупателя передаем заказ №100 от 12.03.2016, в этом случае наш запрос вернет НомерКвартала = 1
Функция Месяц
Принимает параметр типа ДАТА. Возвращает номер месяца даты (целочисленное значение от 1 до 12).
Запрос вернет – 6
Функция ДеньГода
Принимает параметр типа ДАТА. Возвращает номер дня в году (целочисленное значение от 1 до 366).
Запрос вернет – 175
Функция День
Принимает параметр типа ДАТА. Возвращает номер дня в месяце (целочисленное значение от 1 до 31).
Запрос вернет – 23
Функция Неделя
Принимает параметр типа ДАТА. Возвращает номер недели в году.
Запрос вернет – 25
Функция ДеньНедели
Принимает параметр типа ДАТА. Возвращает номер дня недели (целочисленной значение от 1 (понедельник) до 7 (воскресенье)).
Запрос вернет – 4
Функция Час
Принимает параметр типа ДАТА. Возвращает час суток (целочисленное значение от 0 до 23).
Запрос вернет – 18
Функция Минута
Принимает параметр типа ДАТА. Возвращает минуты часа (целочисленное значение от 0 до 59).
Запрос вернет – 25
Функция Секунда
Принимает параметр типа ДАТА. Возвращает секунды минуты (целочисленное значение от 0 до 59).
Запрос вернет – 36
Функция НачалоПериода
Функция возвращает для указанной даты начало периода в который она входит. Период может принимать следующие значения: МИНУТА, ЧАС, ДЕНЬ, НЕДЕЛЯ, МЕСЯЦ, КВАРТАЛ, ГОД, ДЕКАДА, ПОЛУГОДИЕ
Запрос вернет – 01.06.2016
Функция КонецПериода
Функция возвращает для указанной даты конец периода в который она входит. Период может принимать следующие значения: МИНУТА, ЧАС, ДЕНЬ, НЕДЕЛЯ, МЕСЯЦ, КВАРТАЛ, ГОД, ДЕКАДА, ПОЛУГОДИЕ
Запрос вернет – 30.06.2016
Функция ДобавитьКДате
Функция добавляет к дате указанное количество временных интервалов.
Получаем дату 15.10.2016 0:00:00 Очень удобно, что не приходится задумываться о количестве дней в месяцах.
Количество может быть и отрицательным. Тогда отсчет интервала производится в обратную сторону.
Функция РазностьДат
Функция рассчитывает календарную разницу между двумя датами и ее нельзя использовать в местах, где необходимо рассчитать банковских или рабочих дней. Тип может принимать следующие значения: МИНУТА, ЧАС, ДЕНЬ, НЕДЕЛЯ, МЕСЯЦ, КВАРТАЛ, ГОД, ДЕКАДА, ПОЛУГОДИЕ
Дата в 1С 8.3 - это примитивный тип данных, который всегда имеет формат: год, месяц, день, час, минута, секунда. Поэтому переменная типа дата содержит не только дату, но и время. Простой способ создания новой переменной типа дата является приравнивание к переменной строки цифр в одинарных кавычках вида 'ГГГГММДДччммсс' (если часы, минуты и секунды не указывать, то они приравниваются к 00:00:00) где:
✔ Работа с датой и временем
&НаКлиенте
Процедура РаботаСДатойИВременем ( Команда )
// Установка даты в переменную
ТолькоДата = '20200415' ; // 15.04.2020
// Преобразование строки в дату
ТолькоДата = Дата ( "20200415" ); // 15.04.2020
// Преобразование чисел в дату отдельными частями
ТолькоДата = Дата ( 2020 , 04 , 15 ); // 15.04.2020
// Установка в дате: часы, минуты и секунды
ДатаВремя = '20200415162703' ; // 15 апреля 2020 г. 16 ч. 27 мин. 03 сек.
// Получение года (месяца, дня, часа, минуты, секунды) у даты
Год_Даты = Год ( ДатаВремя ); // 2020
Месяц_Даты = Месяц ( ДатаВремя ); // 4
День_Даты = День ( ДатаВремя ); // 15
Час_Даты = Час ( ДатаВремя ); // 16
Минута_Даты = Минута ( ДатаВремя ); // 27
Секунда_Даты = Секунда ( ДатаВремя ); // 03
// Прибавление к дате 3 секунды
Сообщить ( ДатаВремя + 3 ); // 15.04.2020 16:27:06
// Прибавление к дате два месяца
Сообщить ( ДобавитьМесяц ( ДатаВремя , 2 )); // 15.06.2020 16:27:03
// Вычитание от даты одного месяца
Сообщить ( ДобавитьМесяц ( ДатаВремя , - 1 )); // 15.03.2020 16:27:03
// Получение текущей (рабочей) даты
Сообщить ( ТекущаяДата ());
// вариант 1:
&НаКлиенте
Процедура ОперацииДеньДата ( Команда )
Сообщить ( МатематикаДень ( '20200415' , 1 )); //16.04.2020 0:00:00
Сообщить ( МатематикаДень ( '20200415' , - 1 )); //14.04.2020 0:00:00
&НаКлиенте
Функция МатематикаДень ( Дата , ЧислоДней )
Возврат Дата + 86400 * ЧислоДней ; // 86400 сек.
// или вариант 2 (менее универсальный):
&НаКлиенте
Функция ПолучитьСледующийДень ( Дата )
// с помощью функции КонецДня прибавляем секунду к 15.04.2020 23:59:59
&НаКлиенте
Процедура ДополнительныеФункцииДаты ( Команда )
// Указываем дату явно:
ДатаВремя = '20200415162703' ; // 15 апреля 2020 г. 16:27:03
//или
ДатаВремя = '2020.04.15:16:27:03' ; // 15 апреля 2020 г. 16:27:03
Сообщить ( ДеньГода ( ДатаВремя )); // 15
Сообщить ( ДеньНедели ( ДатаВремя )); // 3 - Среда (нумерация с понедельника "1")
Сообщить ( НеделяГода ( ДатаВремя )); // 3 Неделя
Сообщить ( НачалоГода ( ДатаВремя )); // 01.01.2020 0:00:00
Сообщить ( КонецГода ( ДатаВремя )); // 31.12.2020 23:59:59
Сообщить ( НачалоКвартала ( ДатаВремя )); // 01.04.2020 0:00:00
Сообщить ( КонецКвартала ( ДатаВремя )); // 30.06.2020 23:59:59
Сообщить ( НачалоМесяца ( ДатаВремя )); // 01.04.2020 0:00:00
Сообщить ( КонецМесяца ( ДатаВремя )); // 30.04.2020 23:59:59
Сообщить ( НачалоНедели ( ДатаВремя )); // 13.04.2020 0:00:00
Сообщить ( КонецНедели ( ДатаВремя )); // 19.04.2020 23:59:59
Сообщить ( НачалоДня ( ДатаВремя )); // 15.04.2020 0:00:00
Сообщить ( КонецДня ( ДатаВремя )); // 15.04.2020 23:59:59
Сообщить ( НачалоЧаса ( ДатаВремя )); // 15.04.2020 16:00:00
Сообщить ( КонецЧаса ( ДатаВремя )); // 15.04.2020 16:59:59
Сообщить ( НачалоМинуты ( ДатаВремя )); // 15.04.2020 16:27:00
Сообщить ( КонецМинуты ( ДатаВремя )); // 15.04.2020 16:27:59
В 1С значение типа «Дата» – это календарная дата григорианского календаря (с 01 января 0001 года по 31 декабря 3999 год) и время с точностью до 0,1 миллисекунды. Разработчику неизбежно приходится сталкиваться с данным типом, поэтому в этой статье предлагаю ознакомиться с его основными функциями и принципами работы.
«Дата» в модулях 1С
Как инициализировать дату
С помощью литерала встроенного языка
С помощью функции 1С Дата()
Как указать пустую дату
Функции для работы с датой
Получить текущую дату
Получить отдельные части даты
Следует заметить, что пробел в номере года вставляется при установках по умолчанию (подразумевается, что не установлен признак группировки в региональных установках).
Определить дату и время начала некоторого периода из даты
Для решения таких задач существует набор функций НачалоГода(), НачалоКвартала(), НачалоМесяца(), НачалоНедели(), НачалоДня(), НачалоЧаса(), НачалоМинуты(). В параметр задаётся значение даты начало периода, которого необходимо определить.
Определить дату и время конца некоторого периода из даты
Для получения конца периода из даты, можно использовать специальные функции НачалоГода(), НачалоКвартала(), НачалоМесяца(), НачалоНедели(), НачалоДня(), НачалоЧаса(), НачалоМинуты(). Параметр принимает значение «нашей даты», аналогично, как и в функции Начало…().
Определить номер недели или дня в году
Определить номер дня в неделе
Как отнять или прибавить к дате в 1С год, месяц, день, час, минуту, секунду
Если вы только начинаете программировать в 1С или просто хотите систематизировать свои знания - попробуйте Школу программирования 1С нашего друга Владимира Милькина. Пошаговые и понятные уроки даже для новичка с поддержкой учителя.
Попробуйте бесплатно по ссылке >>
Чтобы прибавить, вычесть месяц или год правильно использовать функцию ДобавитьМесяц(, ). Если параметру задать отрицательное значение, то число месяцев отнимается.
Формат даты в 1С
Функция Формат(, ). В параметре перечисляются параметры форматирования через символ «;». Возвращаемый тип строка.
Для задания параметра можно воспользоваться «конструктором форматной строки». При написании кода вызвать его не составляет труда. Необходимо только нажать правую кнопку «мыши» и из контекстного меню выбрать одноимённый конструктор.
На вкладке «Дата» задаём нужный нам формат.
Как вызвать диалоговое окно для ввода даты
Не модальный режим:
«Дата» в запросах 1С
Инициализация даты в запросах
Функция ДАТАВРЕМЯ()
Стоит отметить, что параметры данной функции принимают только литералы в отличие от схожей на неё функции для работы с датой в модулях Дата(). Например запись с передачей в функцию полей выборки из временной таблицы ДАТАВРЕМЯ(вт.Год, вт.Месяц, вт.День) выдаст ошибку.
Пустая дата
Текущая дата и работа с условием по дате в запросе
Так же не стоит забывать, что передать в запрос дату можно с помощью параметра. Для указания текущей даты это единственный вариант.
Получить отдельные части даты. Функции: ГОД, КВАРТАЛ, МЕСЯЦ, ДЕНЬ, ЧАС, МИНУТА, СЕКУНДА
В запросе получить отдельные части даты возможно с помощью одноимённых функций ГОД(), КВАРТАЛ(), МЕСЯЦ(), ДЕНЬ(), ЧАС(), МИНУТА(), СЕКУНДА().
Получить начало, конец некоторого периода
Существует две функции для решения таких задач. Соответственно НАЧАЛОПЕРИОДА(, ) и КОНЕЦПЕРИОДА(, ).
Где в параметр указывается «наша дата», а в параметр задаётся значение периода (Год, Полугодие, Квартал, Месяц, Декада, Неделя, День, Час, Минута).
Аналогично и для функции КОНЕЦПЕРИОДА().
Добавить сдвиг к дате
Для решения таких задач пригодится функция ДОБАВИТЬКДАТЕ(, , ). В параметр задаётся «наша дата», в параметр временной интервал (Год, Полугодие, Месяц и т.д.).
Использование функции РАЗНОСТЬДАТ()
С помощью языка запросов 1С 8 решаются практически все задачи по получению данных в платформе 1С 8.3. Дата — один из часто используемых типов данных. Рассмотрим, как использовать дату в запросах 1С.
Проверка на пустую дату в запросе 1С 8.3
Проверим значение на пустую дату в запросе 1С.
Например, отберем только не закрытые банковские счета из справочника. Критерий того, что они не закрытые, — наличие пустой даты в поле «ДатаЗакрытия»:
ВЫБРАТЬ
БанковскиеСчета.Ссылка
ИЗ
Справочник.БанковскиеСчета КАК БанковскиеСчета
ГДЕ
БанковскиеСчета.ДатаЗакрытия = ДАТАВРЕМЯ(1, 1, 1, 0, 0, 0)
Произвольная дата в языке запросов
Используя функцию ДатаВремя, помимо пустой даты можно указывать и любые другие произвольные даты.
Например, отберем все документы «Счет на оплату покупателю» за месяц, от 1 до 28 февраля:
ВЫБРАТЬ
СчетНаОплатуПокупателю.Ссылка
ИЗ
Документ.СчетНаОплатуПокупателю КАК СчетНаОплатуПокупателю
ГДЕ
СчетНаОплатуПокупателю.Дата МЕЖДУ ДАТАВРЕМЯ(2015, 2, 1, 0, 0, 0) И ДАТАВРЕМЯ(2015, 2, 28, 23, 59, 59)
Текущая дата в запросе
К сожалению, в языке запросов нет аналога метода «ТекущаяДата()», поэтому чтобы получить это значение, его можно передать в запрос с помощью параметра:
Запрос = Новый Запрос;
Запрос.Текст = »
|ВЫБРАТЬ
| СчетНаОплатуПокупателю.Ссылка
|ИЗ
| Документ.СчетНаОплатуПокупателю КАК СчетНаОплатуПокупателю
|ГДЕ
| СчетНаОплатуПокупателю.Дата = &ТекущаяДата«;
Запрос.УстановитьПараметр(«ТекущаяДата», ТекущаяДата());
Если вы только начинаете программировать в 1С или просто хотите систематизировать свои знания - попробуйте Школу программирования 1С нашего друга Владимира Милькина. Пошаговые и понятные уроки даже для новичка с поддержкой учителя.
Попробуйте бесплатно по ссылке >>
Если Вы начинаете изучать 1С программирование, рекомендуем наш бесплатный курс (не забудьте подписаться на YouTube — регулярно выходят новые видео):
Все версии 7.x 8.x ОП 8.2 УП 8.3 УП Видео Добавить FAQРабота с Датами (Временем) | Версия | |
---|---|---|
Ввести дату, ввод даты | [7.x, 8.x] | |
Выбор периода, задать период | [7.x, 8.x] | |
Вычислить возраст человека и выразить его прописью | [8.x] | |
Добавить к Дате указанное количество дней | [8.x] | |
Добавить к Дате указанное количество лет | [8.x] | |
Как Выбрать Месяц формирования отчета? | [8.x, 8.2 УП] | |
Как вывести месяц прописью в родительском падеже?(Як вивести місяц в батьківському відмінку?) | [8.x] | |
Как вычислить количество дней между датами | [7.x, 8.x, 8.2 УП] | |
Как вычислить разницу между двумя датами в днях | [8.x] | |
Как вычислить разницу между двумя датами в месяцах | [8.x] | |
Как вычислить разницу между двумя датами в часах и минутах | [8.x, 8.2 УП] | |
Как перебрать все даты с НачалоПериода по КонецПериода и получить таблицу периодов? | [8.x, 8.2 УП] | |
Как по Номеру Недели Года получить Дату | [8.x, 8.2 УП] | |
Как показать период времени в формате hh:mm:ss | [] | |
Как получить день недели прописью? | [8.3] | |
Как получить количество ЛЕТ, МЕСЯЦЕВ, ДНЕЙ между датами? | [8.x] | |
Как получить количество рабочих дней в месяце по календарю? | [8.x, 8.2 УП, 8.3] | |
Как получить количество часов/минут из интервал с исключением ночного времени | [8.2 УП] | |
Как получить номер Декады месяца ( Например: 1 Декада )? | [7.x, 8.x, 8.2 УП] | |
Как получить текущее время с милисекундами? | [7.x, 8.x, 8.2 УП] | |
Как получить текущую (системную) дату на сервере 1С:Предприятия? | [8.x] | |
Как посчитать разницу между двумя датами? | [7.x, 8.x, 8.2 УП, 8.3] | |
Как преобразовать дату в формат RFC 822 и обратно? | [8.2 УП, 8.3] | |
Как при выполнении обработки сообщить пользователю текущее время и дату? | [8.x] | |
Как прибавить к дате день, месяц? | [8.x] | |
Как проверить дату на пустое значение? | [8.x] | |
Как соединить дату и время? | [8.x, 8.2 УП] | |
Как сравнить две даты (дни)? | [8.x] | |
Как узнать количество дней в месяце? | [8.x, 8.2 УП] | |
Как указать нужную,конкретную дату? | [7.x, 8.x] | |
Количество месяцев и дней между 2-мя датами | [8.x] | |
Месяц прописью и День Прописью | [7.x] | |
Момент Времени и Граница, назначение, примеры использования | [7.x, 8.x] | |
Неправильно рассчитывает номер недели в году, функция корректного расчета | [] | |
Перебор дат, заполнение списка, массива дат по порядку | [8.x] | |
Перевод, преобразование Даты в Строку и Обратно | [8.x, 8.2 УП] | |
Передаем в функцию дату, например 13.08.2009 11:13:54, получаем 13 августа 2009 г. | [8.x] | |
Подсчет реального количества месяцев между датами, включая начало и конец месяца | [8.x, 8.2 УП, 8.3] | |
Преобразование времени в универсальное (GMT) и местное в 1С | [8.x, 8.2 УП] | |
Преобразование даты 1С в unixtime (Unix Time Stamp) | [8.x] | |
Процедура вычисляет количество лет, месяцев и дней между двумя датами | [7.x, 8.x] | |
Пустая дата в запросе и в модуле | [8.x, 8.2 УП] | |
Разница между датами в рабочих днях, подсчет рабочих дней в 1С | [8.x, 8.2 УП, 8.3] | |
Синхронизация времени рабочей станции с сервером | [7.x, 8.x, 8.2 УП] | |
Синхронизация системного Времени по запросу | [8.x] | |
Сколько лет, месяцев, дней прошло между датами | [8.x] | |
Сколько лет, месяцев, дней прошло между датами | [8.x] | |
Строку в дату по форматной строке | [] | |
Функции для работы с датами через запрос (Разность, Добавление, Граница) | [8.x] | |
Функции преобразуют время из представления в виде строки в число и обратно | [8.x] | |
Функция вычисляет даты начала/конца периодов за интервал в виде таблицы значений | [8.x] | |
Функция дата прописью | [8.x] | |
Функция Дата прописью | [7.x, 8.x, 8.2 УП] | |
Функция месяц прописью | [7.x, 8.x] | |
Функция описывает период, определяемый датой и периодичностью | [8.x] | |
Функция переводит Дату в формате 1С в формат вида 'YYYYMMDD hh:mm:ss' и обратно | [8.x, 8.2 УП] | |
Функция пересчитывает сумму из валюты ВалютаНач по курсу КурНач в валюту ВалютаКон по курсу КурКон | [8.x] | |
Функция ПредставлениеПериода() аналог 7-ной функции ПериодСтр() | [8.x, 8.2 УП] | |
Функция преобразует строку вида 04/30/09 в дату | [8.x] | |
Функция преобразует строку вида 31.01.2015 в дату | [8.x, 8.2 УП, 8.3] | |
Функция проверяет является ли передаваемое значение датой или нет | [8.x] |
Читайте также: