Как удалить лишние пробелы перед текстом в Excel: полное руководство

Почему лишние пробелы портят данные в Excel — и как это исправить

Вы когда-нибудь сталкивались с ситуацией, когда в Microsoft Excel или Google Таблицах данные в ячейках выглядят неряшливо из-за лишних пробелов перед текстом? Это не просто эстетическая проблема. Лишние пробелы могут:

искажать результаты сортировки (Excel воспринимает " Привет" и "Привет" как разные значения);

ломать формулы, особенно ВПР, СЧЁТЕСЛИ или ПОИСКПОЗ, которые чувствительны к пробелам;

усложнять анализ данных, если вы импортируете таблицы в другие системы (1С, CRM, базы данных).

К счастью, есть несколько способов очистить данные — от ручных до полностью автоматизированных. В этой статье мы разберём 5 рабочих методов, включая скрытые функции Excel, о которых знают не все. А ещё вы узнаете, как предотвратить появление пробелов при импорте данных из CSV или TX — это сэкономит вам часы ручной правки!

Метод 1: Функция СЖПРОБЕЛЫ — простое решение для большинства случаев

Самый популярный способ удалить пробелы — использовать функцию СЖПРОБЕЛЫ (или TRIM в английской версии). Она убирает:

  • 🔹 Ведущие пробелы (перед текстом);
  • 🔹 Завершающие пробелы (после текста);
  • 🔹 Множественные пробелы между словами (оставляет только один).

Как применить:

  1. В пустой ячейке (например, B1) введите формулу:
    =СЖПРОБЕЛЫ(A1)
  2. Растяните формулу на весь столбец (двойной клик по маркеру автозаполнения).
  3. Скопируйте результаты (Ctrl+C) и вставьте их поверх исходных данных как значения (Правая кнопка → Значения).

⚠️ Внимание: Функция СЖПРОБЕЛЫ не удаляет неразрывные пробелы (вставляются через Ctrl+Shift+Пробел). Для них нужен другой подход — см. Метод 4.

Добавить столбец для формулы|Проверить результат на тестовых данных|Заменить формулы на значения|Удалить вспомогательный столбец-->

Метод 2: Найти и заменить — быстрая правка без формул

Если пробелы одинаковые (например, по 2 пробела перед каждым словом), можно использовать инструмент "Найти и заменить":

  1. Выделите диапазон ячеек (например, A1:A100).
  2. Нажмите Ctrl+H (или Правка → Заменить).
  3. В поле "Найти" введите два пробела (или сколько нужно). В поле "Заменить на" — один пробел.
  4. Нажмите "Заменить всё".

💡 Полезный совет: Чтобы удалить все пробелы перед текстом, в поле "Найти" введите пробел + * (звёздочка как подстановочный знак), а в поле "Заменить на"& (символ "и"). Это заменит " [любой текст]" на "[любой текст]".

Сценарий Что искать На что заменять
Удалить все пробелы перед текстом * (пробел + звёздочка) &
Удалить пробелы в начале и конце * (пробел + звёздочка + пробел) &
Заменить 2 пробела на 1 (два пробела) (один пробел)

⚠️ Внимание: Если в ваших данных есть табуляции (вставляются через Alt+009), этот метод их не удалит. Используйте СЖПРОБЕЛЫ или Макрос VBA.

Функция СЖПРОБЕЛЫ|Найти и заменить|Текст по столбцам|Макросы VBA|Не знаю, как удалять-->

Метод 3: Текст по столбцам — для импортированных данных

Если пробелы появились после импорта из CSV, TXT или базы данных, попробуйте инструмент "Текст по столбцам":

  1. Выделите столбец с пробелами.
  2. Перейдите в Данные → Текст по столбцам.
  3. Выберите "С разделителями""Пробел" (снимите галочки с других разделителей).
  4. Нажмите "Готово".

Excel разобьёт текст по пробелам и распределит по столбцам. Если в исходных данных был только один пробел перед текстом, то:

  • 🔹 В первом столбце останутся пустые ячейки (это и были пробелы).
  • 🔹 Во втором столбце будет чистый текст.

Просто скопируйте второй столбец и вставьте его поверх исходного.

Что делать, если текст разбился на несколько столбцов?

Если после операции "Текст по столбцам" данные разлетелись по 3-4 столбцам, значит в исходном тексте было несколько пробелов подряд. В этом случае:

1. Объедините столбцы с помощью функции СЦЕПИТЬ или CONCATENATE.

2. Примените СЖПРОБЕЛЫ к результату.

3. При необходимости повторите "Текст по столбцам" с другим разделителем (например, табуляцией).

Метод 4: Удаление неразрывных пробелов и других "невидимых" символов

Иногда пробелы не удаляются стандартными способами, потому что это:

  • 🔹 Неразрывные пробелы (вставляются через Ctrl+Shift+Пробел);
  • 🔹 Символы табуляции (Char(9));
  • 🔹 Символы перевода строки (Char(10) или Char(13)).

Для их удаления используйте комбинацию функций:

=СЖПРОБЕЛЫ(ПОДСТАВИТЬ(ПОДСТАВИТЬ(ПОДСТАВИТЬ(A1;СИМВОЛ(160);" ");СИМВОЛ(9);" ");СИМВОЛ(10);" "))

Расшифровка:

  • 🔹 СИМВОЛ(160) — неразрывный пробел;
  • 🔹 СИМВОЛ(9) — табуляция;
  • 🔹 СИМВОЛ(10) — перевод строки.

⚠️ Внимание: Если после применения этой формулы в ячейках появляются знаки #ЗНАЧ!, значит в данных есть другие непечатаемые символы. Используйте макрос VBA для глубокой очистки.

Метод 5: Макрос VBA — автоматическая очистка для больших таблиц

Если у вас тысячи строк, ручная правка займёт слишком много времени. Автоматизируйте процесс с помощью VBA:

  1. Нажмите Alt+F11, чтобы открыть редактор VBA.
  2. Вставьте новый модуль (Insert → Module).
  3. Скопируйте этот код:
    Sub УдалитьПробелы()
    

    Dim rng As Range

    Dim cell As Range

    Set rng = Selection

    For Each cell In rng

    cell.Value = Trim(Replace(Replace(Replace(cell.Value, Chr(160), " "), Chr(9), " "), Chr(10), " "))

    Next cell

    End Sub

  4. Выделите диапазон ячеек в Excel и запустите макрос (F5).

Этот макрос:

  • 🔹 Удаляет все виды пробелов (обычные, неразрывные, табуляции);
  • 🔹 Работает со всеми выделенными ячейками одновременно;
  • 🔹 Сохраняет исходное форматирование (в отличие от "Найти и заменить").

💡 Полезный совет: Чтобы макрос запускался быстрее на больших таблицах, перед кодом добавьте строки:

Application.ScreenUpdating = False

Application.Calculation = xlCalculationManual

А после цикла:

Application.ScreenUpdating = True

Application.Calculation = xlCalculationAutomatic

Это отключит обновление экрана и пересчёт формул во время выполнения.

Как предотвратить появление пробелов в будущем

Лучше не допускать появления пробелов, чем потом их удалять. Вот 3 правила для чистых данных:

  1. Настройте импорт: При открытии CSV/TXT в мастере импорта выбирайте "Разделители" и указывайте правильный символ (запятая, точка с запятой, табуляция).
  2. Используйте шаблоны: Создайте шаблон Excel с СЖПРОБЕЛЫ для часто используемых столбцов (ФИО, адреса, артикулы).
  3. Контролируйте ввод: В Excel 365 используйте "Проверку данных" (Данные → Проверка данных), чтобы блокировать ячейки с ведущими пробелами.

💡 Полезный совет для Google Таблиц: В них есть встроенная функция CLEAN, которая удаляет непечатаемые символы (например, Char(0)Char(31)). Комбинируйте её с TRIM:

=TRIM(CLEAN(A1))

⚠️ Внимание: Если вы работаете с данными, экспортированными из или SAP, пробелы могут появляться из-за настроек выгрузки. Проверьте параметры экспорта в исходной системе — часто там есть опция "Удалять пробелы".

FAQ: Частые вопросы о пробелах в Excel

Можно ли удалить пробелы только в начале текста, но оставить между словами?

Да! Используйте формулу с ПОДСТАВИТЬ и ЛЕВСИМВ:

=ЕСЛИ(ЛЕВСИМВ(A1)=" ";ПОДСТАВИТЬ(A1;" ";"";1);A1)

Эта формула проверяет первый символ. Если это пробел — удаляет его. Для удаления нескольких пробелов подряд используйте рекурсивный подход или макрос.

Почему после применения СЖПРОБЕЛЫ пробелы остаются?

Вероятные причины:

  1. Неразрывные пробелы (Char(160)) — используйте ПОДСТАВИТЬ (см. Метод 4).
  2. Символы табуляции (Char(9)) — замените их на обычные пробелы.
  3. Ячейка отформатирована как текст — попробуйте преобразовать в общий формат (Ctrl+1 → Числовой формат: Общий).
Как удалить пробелы в Google Таблицах?

Аналогично Excel, но с нюансами:

  • 🔹 =TRIM(A1) — аналог СЖПРОБЕЛЫ;
  • 🔹 =CLEAN(A1) — удаляет непечатаемые символы;
  • 🔹 =REGEXREPLACE(A1;"^\s+";"") — удаляет пробелы только в начале (регулярные выражения).

Для массовой замены используйте "Найти и заменить" (Ctrl+H) или Apps Script (аналог VBA).

Можно ли удалить пробелы при сохранении в CSV?

Да, но не через Excel. Используйте:

  • 🔹 Notepad++ с регулярными выражениями (найти: ^\s+, заменить на пустоту);
  • 🔹 Python с библиотекой pandas:
    df['column'] = df['column'].str.strip()
  • 🔹 Онлайн-инструменты вроде TextFixer (для небольших файлов).

⚠️ Внимание: При сохранении из Excel в CSV пробелы могут появиться снова, если в настройках экспорта указан разделитель "Пробел". Выбирайте запятую или точку с запятой.

Как удалить пробелы в защищённых ячейках?

Если лист защищён, сначала:

  1. Перейдите в Рецензирование → Снять защиту листа (потребуется пароль).
  2. Примените один из методов выше.
  3. Верните защиту: Рецензирование → Защитить лист.

Если вы не знаете пароль, используйте VBA для снятия защиты (только для листов, защищённых стандартным паролем Excel):

Sub СнятьЗащиту()

ActiveSheet.Unprotect "password"

End Sub

Замените "password" на реальный пароль (или оставьте пустым, если пароля нет).