Работа с датами в Excel: определение типа и извлечение значений

Иван Корнев·10.04.2026·5 мин

Чтобы определить, является ли значение в Excel датой, используйте функцию =ЕЧИСЛО(ячейка). Если результат ИСТИНА — это корректная дата (число). Для извлечения даты из текста примените =ДАТАЗНАЧ(), а чтобы отделить дату от времени в числовом формате — функцию =ЦЕЛОЕ(). Ниже подробно разобраны все методы конвертации и проверки.

Как понять, что перед вами настоящая дата

В основе работы с датами в Excel лежит принцип серийных номеров: 1 января 1900 года соответствует числу 1, а каждая следующая дата увеличивает это число на единицу. Проблема возникает, когда данные импортируются как текст или имеют неверный формат ячеек.

Для быстрой диагностики используйте следующие методы:

  1. Функция ЕЧИСЛО (ISNUMBER). Введите =ЕЧИСЛО(A1).
    • ИСТИНА: Ячейка содержит число, которое может быть датой.
    • ЛОЖЬ: Ячейка содержит текст. Даже если визуально вы видите «12.05.2024», для Excel это просто набор символов, непригодный для расчетов.
  2. Выравнивание по умолчанию. Числа и даты в Excel по умолчанию выравниваются по правому краю ячейки, текст — по левому.
  3. Формат ячейки. Нажмите Ctrl+1. Если в списке категорий выбрано «Общий» или «Текстовый», а вы ожидаете дату, измените формат на «Дата».

Лайфхак для быстрой проверки: попробуйте изменить формат ячейки на «Общий». Если вместо «10.04.2026» вы увидели число вроде «45757», значит, это корректная дата. Если текст остался прежним — это текстовая строка.

Преобразование текста в дату

Если функция ЕЧИСЛО вернула ЛОЖЬ, необходимо преобразовать текст в числовой формат даты. Выбор метода зависит от структуры данных.

Метод 1: Мастер текстов (для столбцов)

Идеально подходит для массового исправления импортированных данных.

  1. Выделите столбец с датами.
  2. Перейдите на вкладку ДанныеТекст по столбцам.
  3. В мастере нажмите «Далее» дважды до шага 3.
  4. Выберите переключатель Дата и укажите текущий формат ваших данных (например, ДМГ для российского формата).
  5. Нажмите Готово.

Метод 2: Функция ДАТАЗНАЧ (DATEVALUE)

Используется для единичных ячеек или в составе сложных формул. Формула: =ДАТАЗНАЧ(A1)

  • Если в A1 записано "15.04.2026", формула вернет числовое значение даты.
  • Важно: После применения формулы может потребоваться вручную установить формат ячейки «Дата», так как результат вычисления часто отображается как число (например, 45762).

Метод 3: Сборка даты из частей (функция ДАТА)

Если день, месяц и год находятся в разных ячейках или извлечены из текста: =ДАТА(Год; Месяц; День) Пример: =ДАТА(2026; 4; 10) вернет корректную дату 10.04.2026. Эта функция надежнее ДАТАЗНАЧ, так как не зависит от региональных настроек системы.

Извлечение даты из значения со временем

Часто в ячейках хранится комбинация даты и времени (например, 10.04.2026 14:30). Внутренне это десятичная дробь: целая часть — дата, дробная — время.

ЗадачаФормулаПринцип действия
Оставить только дату=ЦЕЛОЕ(A1)Отбрасывает дробную часть (время).
Оставить только время=ОСТАТ(A1;1)Оставляет только дробную часть.
Округлить до дня=ОКРВВЕРХ(A1;1)Альтернативный способ получения даты.

Не забудьте после применения формулы ЦЕЛОЕ применить к ячейке формат «Дата», иначе вы увидите порядковый номер.

Работа со сложными текстовыми строками

Ситуация усложняется, если дата «спрятана» внутри предложения, например: «Заказ №55 от 10.04.2026 выполнен». Здесь стандартные функции не сработают напрямую.

Вариант А: Фиксированная позиция

Если дата всегда находится на одних и тех же символах (например, с 12-го по 21-й символ): =ДАТАЗНАЧ(ПСТР(A1; 12; 10)) Функция ПСТР вырезает кусок текста, а ДАТАЗНАЧ превращает его в дату.

Вариант Б: Динамический поиск (для новых версий Excel)

Если версия Excel поддерживает текстовые функции нового поколения, можно использовать комбинацию поиска и извлечения, но чаще всего для таких задач эффективнее использовать Найти и заменить (Ctrl+H), удалив весь лишний текст, оставив только дату, либо применить Power Query.

Частая ошибка: использование слэшей (/) вместо точек или дефисов при ручном вводе. В русской локали разделителем обычно служит точка. Если система настроена на американский стандарт, она может воспринять «04/10/26» как 10 апреля, а не 4 октября. Всегда проверяйте региональные настройки.

Автоматизация через Power Query

Для обработки больших массивов неструктурированных данных лучше всего подходит надстройка Power Query (вкладка ДанныеПолучить данные).

  1. Преобразуйте диапазон в таблицу (Ctrl+T).
  2. Загрузите данные в редактор Power Query.
  3. Выделите столбец и выберите ПреобразоватьТип данныхДата.
  4. Если данные некорректны, используйте опцию ИзвлечьТекст между разделителями или По примеру, чтобы обучить алгоритм распознаванию паттерна даты.
  5. Нажмите «Закрыть и загрузить».

Этот метод создает воспроизводимый процесс: при добавлении новых строк достаточно обновить запрос, и все даты будут приведены к нужному виду автоматически.

Частые ошибки

  • Дата не суммируется. Причина: данные остались в текстовом формате. Решение: использовать «Текст по столбцам» или умножить диапазон на 1 (=A1*1), затем применить формат даты.
  • Месяц и день поменялись местами. Причина: конфликт локалей (импорт из США/Европы). Решение: при импорте явно указывать формат исходных данных в мастере текстов.
  • Формула возвращает #ЗНАЧ! Обычно означает, что текст в ячейке не распознан как дата (лишние пробелы, недопустимые символы). Используйте функцию СЖПРОБЕЛЫ для очистки перед конвертацией.

FAQ

Вопрос: Почему после формулы ДАТАЗНАЧ я вижу число 45762 вместо даты? Ответ: Функция возвращает внутреннее числовое представление даты. Вам нужно изменить формат ячейки: Правая кнопка мыши → Формат ячеек → Дата.

Вопрос: Как быстро выделить все ячейки с текстовыми датами? Ответ: Используйте фильтр. К сожалению, прямой фильтрации по типу «текст, похожий на дату» нет, но можно добавить вспомогательный столбец с формулой =ЕЧИСЛО(ДАТАЗНАЧ(A1)) и отфильтровать значения ЛОЖЬ.

Вопрос: Можно ли извлечь год, месяц или день отдельно? Ответ: Да. Используйте функции =ГОД(A1), =МЕСЯЦ(A1) и =ДЕНЬ(A1). Они работают только с корректными датами (числами).