Содержание
- Способ 1: Использование автоматического инструмента
- Способ 2: Создание формулы разделения текста
- Шаг 1: Разделение первого слова
- Шаг 2: Разделение второго слова
- Шаг 3: Разделение третьего слова
- Вопросы и ответы
Способ 1: Использование автоматического инструмента
В Excel есть автоматический инструмент, предназначенный для разделения текста по столбцам. Он не работает в автоматическом режиме, поэтому все действия придется выполнять вручную, предварительно выбирая диапазон обрабатываемых данных. Однако настройка является максимально простой и быстрой в реализации.
- С зажатой левой кнопкой мыши выделите все ячейки, текст которых хотите разделить на столбцы.
- После этого перейдите на вкладку «Данные» и нажмите кнопку «Текст по столбцам».
- Появится окно «Мастера разделения текста по столбцам», в котором нужно выбрать формат данных «с разделителями». Разделителем чаще всего выступает пробел, но если это другой знак препинания, понадобится указать его в следующем шаге.
- Отметьте галочкой символ разделения или вручную впишите его, а затем ознакомьтесь с предварительным результатом разделения в окне ниже.
- В завершающем шаге можно указать новый формат столбцов и место, куда их необходимо поместить. Как только настройка будет завершена, нажмите «Готово» для применения всех изменения.
- Вернитесь к таблице и убедитесь в том, что разделение прошло успешно.
Из этой инструкции можно сделать вывод, что использование такого инструмента оптимально в тех ситуациях, когда разделение необходимо выполнить всего один раз, обозначив для каждого слова новый столбец. Однако если в таблицу постоянно вносятся новые данные, все время разделять их таким образом будет не совсем удобно, поэтому в таких случаях предлагаем ознакомиться со следующим способом.
Способ 2: Создание формулы разделения текста
В Excel можно самостоятельно создать относительно сложную формулу, которая позволит рассчитать позиции слов в ячейке, найти пробелы и разделить каждое на отдельные столбцы. В качестве примера мы возьмем ячейку, состоящую из трех слов, разделенных пробелами. Для каждого из них понадобится своя формула, поэтому разделим способ на три этапа.
Шаг 1: Разделение первого слова
Формула для первого слова самая простая, поскольку придется отталкиваться только от одного пробела для определения правильной позиции. Рассмотрим каждый шаг ее создания, чтобы сформировалась полная картина того, зачем нужны определенные вычисления.
- Для удобства создадим три новые столбца с подписями, куда будем добавлять разделенный текст. Вы можете сделать так же или пропустить этот момент.
- Выберите ячейку, где хотите расположить первое слово, и запишите формулу
=ЛЕВСИМВ(
. - После этого нажмите кнопку «Аргументы функции», перейдя тем самым в графическое окно редактирования формулы.
- В качестве текста аргумента указывайте ячейку с надписью, кликнув по ней левой кнопкой мыши на таблице.
- Количество знаков до пробела или другого разделителя придется посчитать, но вручную мы это делать не будем, а воспользуемся еще одной формулой —
ПОИСК()
. - Как только вы запишете ее в таком формате, она отобразится в тексте ячейки сверху и будет выделена жирным. Нажмите по ней для быстрого перехода к аргументам этой функции.
- В поле «Искомый_текст» просто поставьте пробел или используемый разделитель, поскольку он поможет понять, где заканчивается слово. В «Текст_для_поиска» укажите ту же обрабатываемую ячейку.
- Нажмите по первой функции, чтобы вернуться к ней, и добавьте в конце второго аргумента
-1
. Это необходимо для того, чтобы формуле «ПОИСК» учитывать не искомый пробел, а символ до него. Как видно на следующем скриншоте, в результате выводится фамилия без каких-либо пробелов, а это значит, что составление формул выполнено правильно. - Закройте редактор функции и убедитесь в том, что слово корректно отображается в новой ячейке.
- Зажмите ячейку в правом нижнем углу и перетащите вниз на необходимое количество рядов, чтобы растянуть ее. Так подставляются значения других выражений, которые необходимо разделить, а выполнение формулы происходит автоматически.
Полностью созданная формула имеет вид =ЛЕВСИМВ(A1;ПОИСК(" ";A1)-1)
, вы же можете создать ее по приведенной выше инструкции или вставить эту, если условия и разделитель подходят. Не забывайте заменить обрабатываемую ячейку.
Шаг 2: Разделение второго слова
Самое трудное — разделить второе слово, которым в нашем случае является имя. Связано это с тем, что оно с двух сторон окружено пробелами, поэтому придется учитывать их оба, создавая массивную формулу для правильного расчета позиции.
- В этом случае основной формулой станет
=ПСТР(
— запишите ее в таком виде, а затем переходите к окну настройки аргументов. - Данная формула будет искать нужную строку в тексте, в качестве которого и выбираем ячейку с надписью для разделения.
- Начальную позицию строки придется определять при помощи уже знакомой вспомогательной формулы
ПОИСК()
. - Создав и перейдя к ней, заполните точно так же, как это было показано в предыдущем шаге. В качестве искомого текста используйте разделитель, а ячейку указывайте как текст для поиска.
- Вернитесь к предыдущей формуле, где добавьте к функции «ПОИСК»
+1
в конце, чтобы начинать счет со следующего символа после найденного пробела. - Сейчас формула уже может начать поиск строки с первого символа имени, но она пока еще не знает, где его закончить, поэтому в поле «Количество_знаков» снова впишите формулу
ПОИСК()
. - Перейдите к ее аргументам и заполните их в уже привычном виде.
- Ранее мы не рассматривали начальную позицию этой функции, но теперь там нужно вписать тоже
ПОИСК()
, поскольку эта формула должна находить не первый пробел, а второй. - Перейдите к созданной функции и заполните ее таким же образом.
- Возвращайтесь к первому
"ПОИСКУ"
и допишите в «Нач_позиция»+1
в конце, ведь для поиска строки нужен не пробел, а следующий символ. - Кликните по корню
=ПСТР
и поставьте курсор в конце строки «Количество_знаков». - Допишите там выражение
-ПОИСК(" ";A1)-1)
для завершения расчетов пробелов. - Вернитесь к таблице, растяните формулу и удостоверьтесь в том, что слова отображаются правильно.
Формула получилась большая, и не все пользователи понимают, как именно она работает. Дело в том, что для поиска строки пришлось использовать сразу несколько функций, определяющих начальные и конечные позиции пробелов, а затем от них отнимался один символ, чтобы в результате эти самые пробелы не отображались. В итоге формула такая: =ПСТР(A1;ПОИСК(" ";A1)+1;ПОИСК(" ";A1;ПОИСК(" ";A1)+1)-ПОИСК(" ";A1)-1)
. Используйте ее в качестве примера, заменяя номер ячейки с текстом.
Шаг 3: Разделение третьего слова
Последний шаг нашей инструкции подразумевает разделение третьего слова, что выглядит примерно так же, как это происходило с первым, но общая формула немного меняется.
- В пустой ячейке для расположения будущего текста напишите
=ПРАВСИМВ(
и перейдите к аргументам этой функции. - В качестве текста указывайте ячейку с надписью для разделения.
- В этот раз вспомогательная функция для поиска слова называется
ДЛСТР(A1)
, где A1 — та же самая ячейка с текстом. Эта функция определяет количество знаков в тексте, а нам останется выделить только подходящие. - Для этого добавьте
-ПОИСК()
и перейдите к редактированию этой формулы. - Введите уже привычную структуру для поиска первого разделителя в строке.
- Добавьте для начальной позиции еще один
ПОИСК()
. - Ему укажите ту же самую структуру.
- Вернитесь к предыдущей формуле «ПОИСК».
- Прибавьте для его начальной позиции
+1
. - Перейдите к корню формулы
ПРАВСИМВ
и убедитесь в том, что результат отображается правильно, а уже потом подтверждайте внесение изменений. Полная формула в этом случае выглядит как=ПРАВСИМВ(A1;ДЛСТР(A1)-ПОИСК(" ";A1;ПОИСК(" ";A1)+1))
. - В итоге на следующем скриншоте вы видите, что все три слова разделены правильно и находятся в своих столбцах. Для этого пришлось использовать самые разные формулы и вспомогательные функции, но это позволяет динамически расширять таблицу и не беспокоиться о том, что каждый раз придется разделять текст заново. По необходимости просто расширяйте формулу путем ее перемещения вниз, чтобы следующие ячейки затрагивались автоматически.
Еще статьи по данной теме:
Помогла ли Вам статья?
Skip to content
В руководстве объясняется, как разделить ячейки в Excel с помощью формул и стандартных инструментов. Вы узнаете, как разделить текст запятой, пробелом или любым другим разделителем, а также как разбить строки на текст и числа.
Разделение текста из одной ячейки на несколько — это задача, с которой время от времени сталкиваются все пользователи Excel. В одной из наших предыдущих статей мы обсуждали, как разделить ячейки в Excel с помощью функции «Текст по столбцам» и «Мгновенное заполнение». Сегодня мы подробно рассмотрим, как можно разделить текст по ячейкам с помощью формул.
Чтобы разбить текст в Excel, вы обычно используете функции ЛЕВСИМВ (LEFT), ПРАВСИМВ (RIGHT) или ПСТР (MID) в сочетании с НАЙТИ (FIND) или ПОИСК (SEARCH). На первый взгляд, некоторые рассмотренные ниже приёмы могут показаться сложными. Но на самом деле логика довольно проста, и следующие примеры помогут вам разобраться.
Для преобразования текста в ячейках в Excel ключевым моментом является определение положения разделителя в нем. Что может быть таким разделителем? Это запятая, точка с запятой, наклонная черта, двоеточие, тире, восклицательный знак и т.п. И, как мы далее увидим, даже целое слово.
- Как распределить ФИО по столбцам
- Как использовать разделители в тексте
- Разделяем текст по переносам строки
- Как разделить длинный текст на множество столбцов
- Как разбить «текст + число» по разным ячейкам
- Как разбить ячейку вида «число + текст»
- Разделение ячейки по маске (шаблону)
- Использование инструмента Split Text
В зависимости от вашей задачи эту проблему можно решить с помощью функции ПОИСК (без учета регистра букв) или НАЙТИ (с учетом регистра).
Как только вы определите позицию разделителя, используйте функцию ЛЕВСИМВ, ПРАВСИМВ и ПСТР, чтобы извлечь соответствующую часть содержимого.
Для лучшего понимания пошагово рассмотрим несколько примеров.
Делим текст вида ФИО по столбцам.
Если выяснение загадочных поворотов формул Excel — не ваше любимое занятие, вам может понравиться визуальный метод разделения ячеек, который демонстрируется ниже.
В столбце A нашей таблицы записаны Фамилии, имена и отчества сотрудников. Необходимо разделить их на 3 столбца.
Можно сделать это при помощи инструмента «Текст по столбцам». Об этом методе мы достаточно подробно рассказывали, когда рассматривали, как можно разделить ячейку по столбцам.
Кратко напомним:
На ленте «Данные» выбираем «Текст по столбцам» — с разделителями.
Далее в качестве разделителя выбираем пробел.
Обращаем внимание на то, как разделены наши данные в окне образца.
В следующем окне определяем формат данных. По умолчанию там будет «Общий». Он нас вполне устраивает, поэтому оставляем как есть. Выбираем левую верхнюю ячейку диапазона, в который будет помещен наш разделенный текст. Если нужно оставить в неприкосновенности исходные данные, лучше выбрать B1, к примеру.
В итоге имеем следующую картину:
При желании можно дать заголовки новым столбцам B,C,D.
А теперь давайте тот же результат получим при помощи формул.
Для многих это удобнее. В том числе и по той причине, что если в таблице появятся новые данные, которые нужно разделить, то нет необходимости повторять всю процедуру с начала, а просто нужно скопировать уже имеющиеся формулы.
Итак, чтобы выделить из нашего ФИО фамилию, будем использовать выражение
=ЛЕВСИМВ(A2; ПОИСК(» «;A2;1)-1)
В качестве разделителя мы используем пробел. Функция ПОИСК указывает нам, в какой позиции находится первый пробел. А затем именно это количество букв (за минусом 1, чтобы не извлекать сам пробел) мы «отрезаем» слева от нашего ФИО при помощи ЛЕВСИМВ.
Далее будет чуть сложнее.
Нужно извлечь второе слово, то есть имя. Чтобы вырезать кусочек из середины, используем функцию ПСТР.
=ПСТР(A2; ПОИСК(» «;A2) + 1; ПОИСК(» «;A2;ПОИСК(» «;A2)+1) — ПОИСК(» «;A2) — 1)
Как вы, наверное, знаете, функция Excel ПСТР имеет следующий синтаксис:
ПСТР (текст; начальная_позиция; количество_знаков)
Текст извлекается из ячейки A2, а два других аргумента вычисляются с использованием 4 различных функций ПОИСК:
- Начальная позиция — это позиция первого пробела плюс 1:
ПОИСК(» «;A2) + 1
- Количество знаков для извлечения: разница между положением 2- го и 1- го пробелов, минус 1:
ПОИСК(» «;A2;ПОИСК(» «;A2)+1) — ПОИСК(» «;A2) – 1
В итоге имя у нас теперь находится в C.
Осталось отчество. Для него используем выражение:
=ПРАВСИМВ(A2;ДЛСТР(A2) — ПОИСК(» «; A2; ПОИСК(» «; A2) + 1))
В этой формуле функция ДЛСТР (LEN) возвращает общую длину строки, из которой вы вычитаете позицию 2- го пробела. Получаем количество символов после 2- го пробела, и функция ПРАВСИМВ их и извлекает.
Вот результат нашей работы по разделению фамилии, имени и отчества из одной по отдельным ячейкам.
Распределение текста с разделителями на 3 столбца.
Предположим, у вас есть список одежды вида Наименование-Цвет-Размер, и вы хотите разделить его на 3 отдельных части. Здесь разделитель слов – дефис. С ним и будем работать.
- Чтобы извлечь Наименование товара (все символы до 1-го дефиса), вставьте следующее выражение в B2, а затем скопируйте его вниз по столбцу:
=ЛЕВСИМВ(A2; ПОИСК(«-«;A2;1)-1)
Здесь функция мы сначала определяем позицию первого дефиса («-«) в строке, а ЛЕВСИМВ извлекает все нужные символы начиная с этой позиции. Вы вычитаете 1 из позиции дефиса, потому что вы не хотите извлекать сам дефис.
- Чтобы извлечь цвет (это все буквы между 1-м и 2-м дефисами), запишите в C2, а затем скопируйте ниже:
=ПСТР(A2; ПОИСК(«-«;A2) + 1; ПОИСК(«-«;A2;ПОИСК(«-«;A2)+1) — ПОИСК(«-«;A2) — 1)
Логику работы ПСТР мы рассмотрели чуть выше.
- Чтобы извлечь размер (все символы после 3-го дефиса), введите следующее выражение в D2:
=ПРАВСИМВ(A2;ДЛСТР(A2) — ПОИСК(«-«; A2; ПОИСК(«-«; A2) + 1))
Аналогичным образом вы можете в Excel разделить содержимое ячейки в разные ячейки любым другим разделителем. Все, что вам нужно сделать, это заменить «-» на требуемый символ, например пробел (« »), косую черту («/»), двоеточие («:»), точку с запятой («;») и т. д.
Примечание. В приведенных выше формулах +1 и -1 соответствуют количеству знаков в разделителе. В нашем примере это дефис (то есть, 1 знак). Если ваш разделитель состоит из двух знаков, например, запятой и пробела, тогда укажите только запятую («,») в ваших выражениях и используйте +2 и -2 вместо +1 и -1.
Как разбить текст по переносам строки.
Чтобы разделить слова в ячейке по переносам строки, используйте подходы, аналогичные тем, которые были продемонстрированы в предыдущем примере. Единственное отличие состоит в том, что вам понадобится функция СИМВОЛ (CHAR) для передачи символа разрыва строки, поскольку вы не можете ввести его непосредственно в формулу с клавиатуры.
Предположим, ячейки, которые вы хотите разделить, выглядят примерно так:
Напомню, что перенести таким вот образом текст внутри ячейки можно при помощи комбинации клавиш ALT + ENTER.
Возьмите инструкции из предыдущего примера и замените дефис («-») на СИМВОЛ(10), где 10 — это код ASCII для перевода строки.
Чтобы извлечь наименование товара:
=ЛЕВСИМВ(A2; ПОИСК(СИМВОЛ(10);A2;1)-1)
Цвет:
=ПСТР(A2; ПОИСК(СИМВОЛ(10);A2) + 1; ПОИСК(СИМВОЛ(10);A2; ПОИСК(СИМВОЛ(10);A2)+1) — ПОИСК(СИМВОЛ(10);A2) — 1)
Размер:
=ПРАВСИМВ(A2;ДЛСТР(A2) — ПОИСК(СИМВОЛ(10); A2; ПОИСК(СИМВОЛ(10); A2) + 1))
Результат вы видите на скриншоте выше.
Таким же образом можно работать и с любым другим символом-разделителем. Достаточно знать его код.
Как распределить текст с разделителями на множество столбцов.
Изучив представленные выше примеры, у многих из вас, думаю, возник вопрос: «А что, если у меня не 3 слова, а больше? Если нужно разбить текст в ячейке на 5 столбцов?»
Если действовать методами, описанными выше, то формулы будут просто мега-сложными. Вероятность ошибки при их использовании очень велика. Поэтому мы применим другой метод.
Имеем список наименований одежды с различными признаками, перечисленными через дефис. Как видите, таких признаков у нас может быть от 2 до 6. Делим текст в наших ячейках на 6 столбцов так, чтобы лишние столбцы в отдельных строках просто остались пустыми.
Для первого слова (наименования одежды) используем:
=ЛЕВСИМВ(A2; ПОИСК(«-«;A2;1)-1)
Как видите, это ничем не отличается от того, что мы рассматривали ранее. Ищем позицию первого дефиса и отделяем нужное количество символов.
Для второго столбца и далее понадобится более сложное выражение:
=ЕСЛИОШИБКА(ЛЕВСИМВ(ПОДСТАВИТЬ($A2&»-«; ОБЪЕДИНИТЬ(«-«;ИСТИНА;$B2:B2)&»-«;»»;1); ПОИСК(«-«;ПОДСТАВИТЬ($A2&»-«;ОБЪЕДИНИТЬ(«-«;ИСТИНА;$B2:B2)&»-«;»»;1);1)-1);»»)
Замысел здесь состоит в том, что при помощи функции ПОДСТАВИТЬ мы удаляем из исходного содержимого наименование, которое уже ранее извлекли (то есть, «Юбка»). Вместо него подставляем пустое значение «» и в результате имеем «Синий-M-39-42-50». В нём мы снова ищем позицию первого дефиса, как это делали ранее. И при помощи ЛЕВСИМВ вновь выделяем первое слово (то есть, «Синий»).
А далее можно просто «протянуть» формулу из C2 по строке, то есть скопировать ее в остальные ячейки. В результате в D2 получим
=ЕСЛИОШИБКА(ЛЕВСИМВ(ПОДСТАВИТЬ($A2&»-«; ОБЪЕДИНИТЬ(«-«;ИСТИНА;$B2:C2)&»-«;»»;1); ПОИСК(«-«;ПОДСТАВИТЬ($A2&»-«;ОБЪЕДИНИТЬ(«-«;ИСТИНА;$B2:C2)&»-«;»»;1);1)-1);»»)
Обратите внимание, жирным шрифтом выделены произошедшие при копировании изменения. То есть, теперь из исходного текста мы удаляем все, что было уже ранее найдено и извлечено – содержимое B2 и C2. И вновь в получившейся фразе берём первое слово — до дефиса.
Если же брать больше нечего, то функция ЕСЛИОШИБКА обработает это событие и вставит в виде результата пустое значение «».
Скопируйте формулы по строкам и столбцам, на сколько это необходимо. Результат вы видите на скриншоте.
Таким способом можно разделить текст в ячейке на сколько угодно столбцов. Главное, чтобы использовались одинаковые разделители.
Как разделить ячейку вида ‘текст + число’.
Начнем с того, что не существует универсального решения, которое работало бы для всех буквенно-цифровых выражений. Выбор зависит от конкретного шаблона, по которому вы хотите разбить ячейку. Ниже вы найдете формулы для двух наиболее распространенных сценариев.
Предположим, у вас есть столбец смешанного содержания, где число всегда следует за текстом. Естественно, такая конструкция рассматривается Excel как символьная. Вы хотите поделить их так, чтобы текст и числа отображались в отдельных ячейках.
Результат может быть достигнут двумя разными способами.
Метод 1. Подсчитайте цифры и извлеките это количество символов
Самый простой способ разбить выражение, в котором число идет после текста:
Чтобы извлечь числа, вы ищите в строке все возможные числа от 0 до 9, получаете общее их количество и отсекаете такое же количество символов от конца строки.
Если мы работаем с ячейкой A2:
=ПРАВСИМВ(A2;СУММ(ДЛСТР(A2) — ДЛСТР(ПОДСТАВИТЬ(A2; {«0″;»1″;»2″;»3″;»4″;»5″;»6″;»7″;»8″;»9″};»»))))
Чтобы извлечь буквы, вы вычисляете, сколько их у нас имеется. Для этого вычитаем количество извлеченных цифр (C2) из общей длины исходной ячейки A2. После этого при помощи ЛЕВСИМВ отрезаем это количество символов от начала ячейки.
=ЛЕВСИМВ(A2;ДЛСТР(A2)-ДЛСТР(C2))
здесь A2 – исходная ячейка, а C2 — извлеченное число, как показано на скриншоте:
Метод 2: узнать позицию 1- й цифры в строке
Альтернативное решение — использовать эту формулу массива для определения позиции первой цифры:
{=МИН(ПОИСК({0;1;2;3;4;5;6;7;8;9};A2&»0123456789″))}
Как видите, мы последовательно ищем каждое число из массива {0,1,2,3,4,5,6,7,8,9}. Чтобы избежать появления ошибки если цифра не найдена, мы после содержимого ячейки A2 добавляем эти 10 цифр. Excel последовательно перебирает все символы в поисках этих десяти цифр. В итоге получаем опять же массив из 10 цифр — номеров позиций, в которых они нашлись. И из них функция МИН выбирает наименьшее число. Это и будет та позиция, с которой начинается группа чисел, которую нужно отделить от основного содержимого.
Также обратите внимание, что это формула массива и ввод её нужно заканчивать не как обычно, а комбинацией клавиш CTRL
+ SHIFT
+ ENTER
.
Как только позиция первой цифры найдена, вы можете разделить буквы и числа, используя очень простые формулы ЛЕВСИМВ и ПРАВСИМВ.
Чтобы получить текст:
=ЛЕВСИМВ(A2; B2-1)
Чтобы получить числа:
=ПРАВСИМВ(A2; ДЛСТР(A2)-B2+1)
Где A2 — исходная строка, а B2 — позиция первого числа.
Чтобы избавиться от вспомогательного столбца, в котором мы вычисляли позицию первой цифры, вы можете встроить МИН в функции ЛЕВСИМВ и ПРАВСИМВ:
Для вытаскивания текста:
=ЛЕВСИМВ(A2; МИН(ПОИСК({0;1;2;3;4;5;6;7;8;9};A2&»0123456789″))-1)
Для чисел:
=ПРАВСИМВ(A2; ДЛСТР(A2)-МИН(ПОИСК({0;1;2;3;4;5;6;7;8;9};A2&»0123456789″))+1)
Этого же результата можно достичь и чуть иначе.
Сначала мы извлекаем из ячейки числа при помощи вот такого выражения:
=ПРАВСИМВ(A2;СУММ(ДЛСТР(A2) -ДЛСТР(ПОДСТАВИТЬ(A2; {«0″;»1″;»2″;»3″;»4″;»5″;»6″;»7″;»8″;»9″};»»))))
То есть, сравниваем длину нашего текста без чисел с его исходной длиной, и получаем количество цифр, которое нужно взять справа. К примеру, если текст без цифр стал короче на 2 символа, значит справа надо «отрезать» 2 символа, которые и будут нашим искомым числом.
А затем уже берём оставшееся:
=ЛЕВСИМВ(A2;ДЛСТР(A2)-ДЛСТР(C2))
Как видите, результат тот же. Можете воспользоваться любым способом.
Как разделить ячейку вида ‘число + текст’.
Если вы разделяете ячейки, в которых буквы стоят после цифр, вы можете отделять числа по следующей формуле:
=ЛЕВСИМВ(A2;СУММ(ДЛСТР(A2) — ДЛСТР(ПОДСТАВИТЬ(A2; {«0″;»1″;»2″;»3″;»4″;»5″;»6″;»7″;»8″;»9″};»»))))
Она аналогична рассмотренной в предыдущем примере, за исключением того, что вы используете функцию ЛЕВСИМВ вместо ПРАВСИМВ, чтобы получить число теперь уже из левой части выражения.
Теперь, когда у вас есть числа, отделите буквы, вычитая количество цифр из общей длины исходной строки:
=ПРАВСИМВ(A2;ДЛСТР(A2)-ДЛСТР(B2))
Где A2 — исходная строка, а B2 — искомое число, как показано на снимке экрана ниже:
Как разбить текст по ячейкам по маске (шаблону).
Эта опция очень удобна, когда вам нужно разбить список схожих строк на некоторые элементы или подстроки. Сложность состоит в том, что исходный текст должен быть разделен не при каждом появлении определенного разделителя (например, пробела), а только при некоторых определенных вхождениях. Следующий пример упрощает понимание.
Предположим, у вас есть список строк, извлеченных из некоторого файла журнала:
Вы хотите, чтобы дата и время, если таковые имеются, код ошибки и поясняющие сведения были размещены в 3 отдельных столбцах. Вы не можете использовать пробел в качестве разделителя, потому что между датой и временем также есть пробелы. Также есть пробелы в тексте пояснения, который также должен весь находиться слитно в одном столбце.
Решением является разбиение строки по следующей маске: * ERROR: * Exception: *
Здесь звездочка (*) представляет любое количество символов.
Двоеточия (:) включены в разделители, потому что мы не хотим, чтобы они появлялись в результирующих ячейках.
То есть в данном случае в качестве разделителя по столбцам выступают не отдельные символы, а целые слова.
Итак, в начале ищем позицию первого разделителя.
=ПОИСК(«ERROR:»;A2;1)
Затем аналогичным образом находим позицию, в которой начинается второй разделитель:
=ПОИСК(«Exception:»;A2;1)
Итак, для ячейки A2 шаблон выглядит следующим образом:
С 1 по 20 символ – дата и время. С 21 по 26 символ – разделитель “ERROR:”. Далее – код ошибки. С 31 по 40 символ – второй разделитель “Exception:”. Затем следует описание ошибки.
Таким образом, в первый столбец мы поместим первые 20 знаков:
=—ЛЕВСИМВ(A2;ПОИСК(«ERROR:»;A2;1)-1)
Обратите внимание, что мы взяли на 1 позицию меньше, чем начало первого разделителя. Кроме того, чтобы сразу конвертировать всё это в дату, ставим перед формулой два знака минус. Это автоматически преобразует цифры в число, а дата как раз и хранится в виде числа. Остается только установить нужный формат даты и времени стандартными средствами Excel.
Далее нужно получить код:
=ПСТР(A2;ПОИСК(«ERROR:»;A2;1)+6;ПОИСК(«Exception:»;A2;1)-(ПОИСК(«ERROR:»;A2;1)+6))
Думаю, вы понимаете, что 6 – это количество знаков в нашем слове-разделителе «ERROR:».
Ну и, наконец, выделяем из этой фразы пояснение:
=ПРАВСИМВ(A2;ДЛСТР(A2)-(ПОИСК(«Exception:»;A2;1)+10))
Аналогично добавляем 10 к найденной позиции второго разделителя «Exception:», чтобы выйти на координаты первого символа сразу после разделителя. Ведь функция говорит нам только то, где разделитель начинается, а не заканчивается.
Таким образом, ячейку мы распределили по 3 столбцам, исключив при этом слова-разделители.
Если выяснение загадочных поворотов формул Excel — не ваше любимое занятие, вам может понравиться визуальный метод разделения ячеек в Excel, который демонстрируется в следующей части этого руководства.
Как разделить ячейки в Excel с помощью функции разделения текста Split Text.
Альтернативный способ разбить столбец в Excel — использовать функцию разделения текста, включенную в надстройку Ultimate Suite for Excel. Она предоставляет следующие возможности:
- Разделить ячейку по символу-разделителю.
- Разделить ячейку по нескольким разделителям.
- Разделить ячейку по маске (шаблону).
Чтобы было понятнее, давайте более подробно рассмотрим каждый вариант по очереди.
Разделить ячейку по символу-разделителю.
Выбирайте этот вариант, если хотите разделить содержимое ячейки при каждом появлении определённого символа .
Для этого примера возьмем строки шаблона Товар-Цвет-Размер , который мы использовали в первой части этого руководства. Как вы помните, мы разделили их на 3 разных столбца, используя 3 разные формулы . А вот как добиться того же результата за 2 быстрых шага:
- Предполагая, что у вас установлен Ultimate Suite , выберите ячейки, которые нужно разделить, и щелкните значок «Разделить текст (Split Text)» на вкладке «Ablebits Data».
- Панель Разделить текст откроется в правой части окна Excel, и вы выполните следующие действия:
- Разверните группу «Разбить по символам (Split by Characters)» и выберите один из предопределенных разделителей или введите любой другой символ в поле «Пользовательский (Custom)» .
- Выберите, как именно разбивать ячейки: по столбцам или строкам.
- Нажмите кнопку «Разделить (Split)» .
Примечание. Если в ячейке может быть несколько последовательных разделителей (например, более одного символа пробела подряд), установите флажок « Считать последовательные разделители одним».
Готово! Задача, которая требовала 3 формул и 5 различных функций, теперь занимает всего пару секунд и одно нажатие кнопки.
Разделить ячейку по нескольким разделителям.
Этот параметр позволяет разделять текстовые ячейки, используя любую комбинацию символов в качестве разделителя. Технически вы разделяете строку на части, используя одну или несколько разных подстрок в качестве границ.
Например, чтобы разделить предложение на части, используя запятые и союзы, активируйте инструмент «Разбить по строкам (Split by Strings)» и введите разделители, по одному в каждой строке:
В данном случае в качестве разделителей мы используем запятую и союз “или”.
В результате исходная фраза разделяется при появлении любого разделителя:
Примечание. Союзы «или», а также «и» часто могут быть частью слова в вашей исследуемой фразе, так что не забудьте ввести пробел до и после них, чтобы предотвратить разрывы слов на части.
А вот еще один пример. Предположим, вы импортировали столбец дат из внешнего источника, и выглядит он следующим образом:
5.1.2021 12:20
9.8.2021 14:50
Этот формат не является обычным для Excel, и поэтому ни одна из функций даты не распознает здесь какие-либо элементы даты или времени. Чтобы разделить день, месяц, год, часы и минуты на отдельные ячейки, введите следующие символы в поле Spilt by strings:
- Точка (.) Для разделения дня, месяца и года
- Двоеточие (:) для разделения часов и минут
- Пробел для разграничения даты и времени
Нажмите кнопку Split, и вы сразу получите результат:
Разделить ячейки по маске (шаблону).
Эта опция очень удобна, когда вам нужно разбить список однородных строк на некоторые элементы или подстроки.
Сложность заключается в том, что исходный текст не может быть разделен при каждом появлении заданного разделителя, а только при некоторых определенных вхождениях. Следующий пример упростит понимание.
Предположим, у вас есть список строк, извлеченных из некоторого файла журнала. Чуть выше в этой статье мы разбивали этот текст по ячейкам при помощи формул. А сейчас используем специальный инструмент. И вы сами решите, какой из способов удобнее и проще.
Вы хотите, чтобы дата и время, если таковые имеются, код ошибки и пояснительная информация, были в трех отдельных столбцах. Вы не можете использовать пробел в качестве разделителя, потому что между датой и временем имеются пробелы, которые должны отображаться в одном столбце, и есть пробелы в тексте пояснения, который также должен быть расположен в отдельном столбце.
Решением является разбиение строки по следующей маске:
* ERROR:* Exception: *
Где звездочка (*) представляет любое количество символов.
Двоеточия (:) включены в разделители, потому что мы не хотим, чтобы они появлялись в результирующих ячейках.
А теперь нажмите кнопку «Разбить по маске (Split by Mask)» на панели «Split Text» , введите маску в соответствующее поле и нажмите «Split».
Результат будет примерно таким:
Примечание. При разделении строки по маске учитывается регистр. Поэтому не забудьте ввести символы в шаблоне точно так, как они отображаются в исходных данных.
Большое преимущество этого метода — гибкость. Например, если все исходные строки имеют значения даты и времени, и вы хотите, чтобы они отображались в разных столбцах, используйте эту маску:
* * ERROR:* Exception: *
Проще говоря, маска указывает надстройке разделить исходные строки на 4 части:
- Все символы перед 1-м пробелом в строке (дата)
- Символы между 1-м пробелом и словом ERROR: (время)
- Текст между ERROR: и Exception: (код ошибки)
- Все, что идет после Exception: (текст описания)
Думаю, вы согласитесь, что использование надстройки Split Text гораздо быстрее и проще, нежели использование формул.
Надеюсь, вам понравился этот быстрый и простой способ разделения строк в Excel. Если вам интересно попробовать, ознакомительная версия доступна для загрузки здесь.
Вот как вы можете разделить текст по ячейкам таблицы Excel, используя различные комбинации функций, а также специальные инструменты. Благодарю вас за чтение и надеюсь увидеть вас в нашем блоге на следующей неделе!
Читайте также:
Как разбить ячейки в Excel: «Текст по столбцам», «Мгновенное заполнение» и формулы
Смотрите также описана функция: квадратной скобки. Вычисление решением является гибкая ячейках удаляются. кнопку «OK».«Главная»AL имена с суффиксами Синтаксис формулы:(НАЙТИ), о чём яНа следующем шаге выберите другую рабочую книгу, кавычки (например, «California, хотите разделить данные.Необходимо разбить этот текстВ этой статье ВыFunction Substring(Txt, Delimiter,
в третьем аргументе формула основана наНажмите стрелку вниз рядомПосле этого, ячейка будетв блоке инструментовMontgomery в конце:=LEFT(text,[num_chars])SEARCH говорю из следующего формат данных и попытка сделать это USA»), будут помещеныВыделите столбец, который требуется на отдельные столбцы, найдёте несколько способов, n) As String более сложное и текстовых функциях. с кнопкой разделена косой чертой
- «Шрифт»Извлекаем название штата:A
- =ЛЕВСИМВ(текст;[количество_знаков])(ПОИСК) и
- примера. укажите ячейки, куда приведёт к сообщению
- в одну ячейку. разбить. Затем откройте чтобы таблица имела
Разбиваем ячейки в Excel при помощи инструмента «Текст по столбцам»
как разбить ячейкиDim x As оно подразумевает вычитаниеВ ячейку B3 введитеОбъединить и поместить в по диагонали. Но,жмем на иконку=LEFT(A2,SEARCH(«,»,A2)-1)B
В качестве аргументов указываем:LENПервым делом, убедитесь, что поместить результат, как об ошибке выбора Если же в вкладку следующие данные (слева или целые столбцы
- Variant одной большей длинны
- следующую формулу: центре
Разбиваем текстовые данные с разделителями по столбцам в Excel
нужно учесть, что«Границы»=ЛЕВСИМВ(A2;ПОИСК(«,»;A2)-1)C какой текст взять(ДЛСТР). Далее в инструмент «Мгновенное заполнение» это было сделано конечной ссылки. качестве ограничителя строк
Data направо): в Excel 2010x = Split(Txt, текста от меньшей.Теперь скопируйте эту формулу. Excel воспринимает этим. В появившемся спискеИзвлекаем аббревиатуру штата:D и сколько символов этом разделе я включен. Вы найдёте в предыдущем примере,Совет:
- установить значение(Данные) >First Name и 2013. Приведённые Delimiter) А чтобы учитывать вдоль целого столбца:Выберите способом разделенную ячейку, выбираем пункт «Все=MID(A2,SEARCH(«,»,A2)+2,SEARCH(«,»,A2,SEARCH(«,»,A2)+2)-SEARCH(«,»,A2)-2)1 извлечь. В следующем кратко объясню назначение этот параметр на а затем нажмитеЕсли Вы неNoneData Tools(Имя), примеры и скриншотыIf n > еще 2 пробелаВыборка чисел из строкОтменить объединение ячеек. как единый элемент. границы».=ПСТР(A2;ПОИСК(«,»;A2)+2;ПОИСК(«,»;A2;ПОИСК(«,»;A2)+2)-ПОИСК(«,»;A2)-2)Полное имя примере формула будет каждой из этих вкладкеFinish хотите импортировать какой-то(Нет), тогда слово(Работа с данными)Last Name иллюстрируют работу с 0 And n следует вычитать число в отдельные ячейки.Важно:Следующий способ подойдет дляКак видим, несмотря наИзвлекаем столицу штата:Имя извлекать левую часть
функций и приведуFile(Готово). столбец (столбцы), который «California» будет помещено >
(Фамилия), инструментами «Текст по — 1 Substring 3. В результате разделения ячейки по то, что мы=RIGHT(A2,LEN(A2)-(SEARCH(«,»,A2,SEARCH(«,»,A2)+1)+1))Фамилия текста из ячейки примеры, которые Вы(Файл) >Если Вы объединили несколько показан в области
- в один столбец,Text to ColumnsCountry столбцам» и «Мгновенное = x(n - чего получаем правильноеФункция ПСТР возвращает текстовоеЯчейку, которая не была диагонали только в ничего не делили,
- =ПРАВСИМВ(A2;ДЛСТР(A2)-(ПОИСК(«,»;A2;ПОИСК(«,»;A2)+1)+1))СуффиксA2 сможете использовать вOptions ячеек на листеData preview а «USA» –(Текст по столбцам).(Страна), заполнение», кроме этого 1) количество символов в значение содержащие определенное создана путем объединения, том случае, если а наоборот соединяли,А вот пример реальных2вплоть до позиции
- своих книгах Excel.(Параметры) > Excel и теперь(Образец разбора данных),
- в другой.Откроется диалоговое окноArrival Date Вы увидите подборкуElse разделенной строке. С количество символов в невозможно разделить. Если она большая, или создается иллюзия разделенной данных из ExcelRobert Furlan Jr. первого найденного пробела.Самая распространённая ситуация, когдаAdvanced хотите вновь разбить то выделите егоВ нижней части диалоговогоConvert Text to Columns(Ожидаемая дата прибытия) формул для разделенияSubstring = «» помощью такой гибкой строке. Аргументы функции: вы ищете сведения создана путем объединения ячейки. 2010. Данные изRobert
- =LEFT(A2,SEARCH(» «,A2)-1) могут понадобится эти(Дополнительно) > их по отдельным и выберите вариант окна находится область wizard и имён, текстовых иEnd If формулы можно делатьПервый аргумент – это о том, как нескольких ячеек.Урок: Как объединить ячейки первого столбца разбитыFurlan=ЛЕВСИМВ(A2;ПОИСК(» «;A2)-1) формулы – этоAutomatically Flash Fill столбцам, откройте вкладкуDo not import columnData preview(Мастер распределения текстаStatus числовых значений. ЭтотEnd Function выборку разной длинны ссылка на ячейку распределить данные изНаходясь во вкладке
в программе Excel на три отдельныхJr.LEN необходимость разделить имена(Автоматически выполнять мгновенноеHome(Пропустить столбец) в(Образец разбора данных). по столбцам). На(Статус). урок поможет Вам
- в другой.Откроется диалоговое окноArrival Date Вы увидите подборкуElse разделенной строке. С количество символов в невозможно разделить. Если она большая, или создается иллюзия разделенной данных из ExcelRobert Furlan Jr. первого найденного пробела.Самая распространённая ситуация, когдаAdvanced хотите вновь разбить то выделите егоВ нижней части диалоговогоConvert Text to Columns(Ожидаемая дата прибытия) формул для разделенияSubstring = «» помощью такой гибкой строке. Аргументы функции: вы ищете сведения создана путем объединения ячейки. 2010. Данные изRobert
- Например в ячейке А1 разделенного текста из с исходным текстом. ячейки по нескольким«Вставка»Если нам нужно разделить столбца:Извлекаем имя:(ДЛСТР) – считает из одного столбца заполнение).(Главная) и в разделе Прежде чем нажать первом шаге мастераЕсли в таблице есть выбрать наилучший метод предложение: разных длинны исходныхВторой аргумент – это ячейкам, см. статью, в блоке инструментов ячейку не вУрок подготовлен для Вас=LEFT(A2,FIND(» «,A2,1)-1) длину строки, то по нескольким. НаТеперь давайте посмотрим, как группе командColumn data formatNext Вы выбираете формат хотя бы один разбиения данных вКак в Эксель строк. позиция первого символа, Распределение содержимого ячейки
«Иллюстрации», кликаем по шапке, а в командой сайта office-guru.ru=ЛЕВСИМВ(A2;НАЙТИ(» «;A2;1)-1) есть количество символов рисунке ниже показано, можно автоматически разбитьAlignment(Формат данных столбца).(Далее) будет разумным данных. Так как столбец справа от Excel. Excel расцепить, разъединитьАля с которого должна на соседние столбцы. кнопке середине таблицы, тоИсточник: https://www.ablebits.com/office-addins-blog/2014/02/27/split-cells-excel/Извлекаем фамилию: в заданной ячейке. какого результата мы данные по ячейкам.(Выравнивание) нажмите маленькуюНажмите
пролистать это поле записи разделены пробелами столбца, который необходимоГоворя в общем, необходимость текст или предложение: Здравствуйте! начинаться разделенная строка.Ячейку, полученную путем объединения,«Фигуры» в этом случае,Перевел: Антон Андронов=MID(A2,FIND(» «,A2,1)+1,FIND(» «,A2,FIND(» «,A2,1)+1)-(FIND(« Синтаксис формулы: пытаемся достичь:
- Итак, Вы включили чёрную стрелку рядомFinish
Разбиваем текст фиксированной ширины по нескольким столбцам
и убедиться, что и запятыми, мы разбить, тогда первым разбить ячейки в из одной ячейкиПодскажите пожалуйста, какаяПоследний аргумент – это
можно снова разделить. легче объединить всеАвтор: Антон Андронов «,A2,1)+1))=LEN(text)Вы легко сможете разбить
инструмент «Мгновенное заполнение», с кнопкой(Готово)! Excel правильно распределил
- выбираем формат делом создайте новые Excel может возникнуть на две ячейки есть функция обратная количество символов, которое на отдельные ячейки.В открывшемся меню, в ячейки двух соседнихПри работе с таблицами=ПСТР(A2;НАЙТИ(» «;A2;1)+1;НАЙТИ(» «;A2;НАЙТИ(» «;A2;1)+1)-(НАЙТИ(«=ДЛСТР(текст) такие имена на
- и начинаете вводитьMerge & CenterЕсли данные состоят из все данные поDelimited пустые столбцы, в в двух случаях: по необходимой длине, функции расцепить. должна содержать разделенная Если вы не блоке столбцов, а уже Excel иногда нужно «;A2;1)+1))Следующая формула считает количество два столбца при с клавиатуры данные,(Объединить и поместить текстовых или числовых столбцам.(С разделителями). Вариант которые будут помещены
Во-первых, при импорте если в нёмНапример в одной строка. помните, где находятся«Линии» потом произвести разделение
- разбить определенную ячейкуИзвлекаем суффикс: символов в ячейке помощи следующих формул: которые нужно поместить в центре). Далее значений с фиксированнымОсталось сделать всего двеFixed width
Разбиваем объединённые ячейки в Excel
полученные данные. Этот информации из какой-либо много слов и ячейке (0609), аС первым аргументом ПСТР объединенные ячейки, используйте, кликаем по самой нужной ячейки. на две части.=RIGHT(A2,LEN(A2)-FIND(» «,A2,FIND(» «,A2,1)+1))A2Извлекаем имя (столбец First в отдельные ячейки. из выпадающего списка количеством символов, Вы вещи – выбрать(Фиксированной ширины) будет шаг необходим для внешней базы данных символов
надо (06)(09). все понятно – команду первой фигуре.Выделяем два соседних столбца. Но, это не=ПРАВСИМВ(A2;ДЛСТР(A2)-НАЙТИ(» «;A2;НАЙТИ(» «;A2;1)+1)): name): По мере ввода выберите можете разбить их формат данных и рассмотрен чуть позже. того, чтобы результаты
Разделяем данные на несколько столбцов в Excel 2013 при помощи мгновенного заполнения
или с веб-страницы.Надо что быСпасибо это ссылка наНайтиПроводим линию от угла Кликаем на стрелку так просто, какА вот формулы, позволяющие=LEN(A2)=LEFT(A2,SEARCH(» «,A2,1)-1)
Excel будет пытатьсяUnmerge Cells на несколько столбцов указать, куда поместить Если все готово, не были записаны При таком импорте в ячейке С1Marchuk ячейку A3. Второйдля их поиска. к углу ячейки около кнопки кажется на первый разбить имена с=ДЛСТР(A2)=ЛЕВСИМВ(A2;ПОИСК(» «;A2;1)-1) распознать шаблон в(Отменить объединение ячеек). следующим способом.
разделённые ячейки.В разделе жмите поверх уже существующих все записи копируются было:: =ЛЕВСИМВ() аргумент мы вычисляемЧасто приходится оптимизировать структуру в том, направлении,«Объединить и поместить в взгляд. Давайте разберемся, фамилией, стоящей впереди
Если имена в ВашейИзвлекаем фамилию (столбец Last вводимых значениях, иТаким образом объединение ячеекК примеру, есть списокColumn data formatNext данных.В нашем примере в один столбец,Как в Эксель=ПРАВСИМВ() с помощью функции данных после импорта которое вам требуется.
центре» как разбить ячейку и отделенной от таблице содержат отчества name): как только он будет отменено, но товаров с ID(Формат данных столбца)(Далее), чтобы продолжить. сразу после столбца а нужно, чтобы Excel расцепить, разъединить=ПСТР() НАЙТИ(«]»;A3)+2. Она возвращает в Excel. НекоторыеКак видим, несмотря на. В появившемся списке, на две части имени запятой, и
или суффиксы, то=RIGHT(A2,LEN(A2)-SEARCH(» «,A2,1)) его распознает, данные удовольствие от результата и наименованием, причем Вы можете выбратьНа следующем шаге определяемParticipant они были помещены текст или предложениеZ очередной номер символа разные значения попадают то, что в кликаем по пункту в программе Microsoft
отчеством, находящимся в потребуются немного более=ПРАВСИМВ(A2;ДЛСТР(A2)-ПОИСК(» «;A2;1)) автоматически будут вставлены будет испорчено тем, идентификатор товара – формат данных отдельно разделители, которые содержатсянаходится столбец в разных столбцах. из одной ячейки: Могзи набекрень: таки первой закрывающейся квадратной в одну и
Как в Excel разбивать ячейки при помощи формул
программе Microsoft Excel«Объединить по строкам» Excel, и как конце: сложные формулы сДля тех, кому интересно, в остальные ячейки. что все данные это 9 символов, для каждого столбца, в данных, иStatus Во-вторых, при разбиении на две ячейки да или таки скобки в строке. туже ячейку образуя не существует стандартных. её разделить поA использованием функции что означают эти Чтобы понять, как останутся в левом которые стоят перед в которые будут ограничитель строк., и мы собираемся
Пример 1
уже существующей таблицы, по нет надо из И к этому целую строку как способов разбить первичнуюКликаем по той объединенной диагонали.B
MID формулы, я попробую это работает, посмотрите столбце. Думаю, Вы
- наименованием этого товара: помещены разделённые данные.
Настраиваем разделители
добавить между ними
- чтобы получить возможностьНадо чтобы в
ниже...
номеру мы добавляем
одно значение. Возникает ячейку на части, ячейке, которую нужноСкачать последнюю версию
C(ПСТР). объяснить более подробно. на рисунок ниже: догадались, что нужноВот что Вам нужно По умолчанию для. Если данные разделены новые столбцы
качественнее настроить работу
ячейке С2 было
Тема — «обратная еще число 2, вопрос: как разбить с помощью нескольких разделить. Опять жмем ExcelDВот такие формулы нужноSEARCHКак видите, я ввёл снова использовать функцию сделать, чтобы разбить всех столбцов задан одним или несколькимиLast Name фильтра, сортировку или остальное предложение: функция функции -
так как нам строку на ячейки способов можно достигнуть на стрелку околоСразу нужно отметить, что1 использовать, когда имена,(ПОИСК) или только пару имён
Text to Columns
такой столбец на
формат разделителями, то нужно, для более детальногонеобходимой длине, если сцепить»; нужен номер символа в Excel. Программа
требуемого результата.
кнопки
ячейки в программеПолное имя которые требуется разбить,FIND в столбец(Текст по столбцам), два:General выбрать все подходящиеCountry
анализа.
в нём много
вопрос — «функция после пробела за располагает разными поисковымиАвтор: Максим Тютюшев«Объединить и поместить в Microsoft Excel являются
Имя
содержат отчество или
(НАЙТИ) – этоB чтобы разбить данныеЗапустите инструмент
(Общий). Мы оставим
варианты в разделе
иРазбиваем ячейки при помощи слов и символов обратная функции расцепить». квадратной скобкой. В функциями: одни ищутПримечание: центре»
Пример 2
первичными структурными элементами,Отчество только один инициал абсолютно идентичные функции,, и «Мгновенное заполнение» из одного столбца
Text to Columns | его без изменений | D | Arrival Date | |
инструмента «Текст по | Вот пример формулы | ps Экстрасенсов, телепатов | последнем аргументе функция | по ячейках другие |
Мы стараемся как можно | . На этот раз | и они не | Фамилия | отчества посередине. |
- которые выполняют поиск
автоматически заполнило остальные
на два или
- (Текст по столбцам),
для первых трёхelimiters
.Если кто-то забыл, я столбцам»
- как расцепить текст
и прочих энтузазистов
вычисляет какое количество
ищут по содержимому оперативнее обеспечивать вас выбираем пункт подлежат делению на2A
позиции определенной текстовой
ячейки именами из
более столбцов. как мы это столбцов, а для(Символом-разделителем является) или напомню быстрый способКак разбить объединённые ячейки
Пример 3
если в нём прошу не шуметь символов будет содержать ячеек. Ведь выполнять
актуальными справочными материалами | «Отменить объединение» | более мелкие части, | White, David Mark | |
B | строки в заданной | столбца | Если Вы уже обновились | делали в предыдущем |
четвёртого столбца установим | ввести свой вариант | вставить сразу несколько | в Excel | два слова: |
- — может автор
разделенная строка после
поиск по текстовой
- на вашем языке.
. если до этого
DavidC
- ячейке. Синтаксис формулы:
A
до Excel 2013,
Пример 4
примере. На первом формат разделителя в поле столбцов на листРазделяем данные в ExcelЯчейка А1: Добрый сам определиться…
разделения, учитывая положение | строке, которая содержится | Эта страница переведена | Таким образом, мы получили | |
не были объединены. | Mark | D | =SEARCH(find_text,within_text,[start_num]) | . Если вы довольны |
то можете воспользоваться | шаге мастера выберите | Data | Other | Excel. Для этого |
- 2013 при помощи
деньАля
квадратной скобки. в ячейке ¬–
- автоматически, поэтому ее
разделенную ячейку. Но,
Но, что делать,
- White
1
=ПОИСК(искомый_текст;текст_для_поиска;[нач_позиция])
Пример 5
результатом, просто нажмите преимуществами нового инструмента параметр(Дата), что логично,(Другой).В нашем примере выберите столбец инструмента «Мгновенное заполнение»Ячейка С1 формула:: Могзи набекрень: такиОбратите внимание! Что в это также распространенная текст может содержать нужно учесть, что
если нам, например, | Извлекаем имя: | Полное имя | В качестве аргументов Вы | |
Enter | « | Fixed width | ведь в этот | мы выбираем |
Status | Формулы для разбиения столбцов | =ПСТР (A1;1;НАЙТИ (« | да или таки | нашем примере все |
- потребность пользователей Excel.
неточности и грамматические
Excel воспринимает этим
- нужно создать сложную
=MID(A2,SEARCH(" ",A2,1)+1,FIND(" ",A2,FIND(" ",A2,1)+1)-(FIND("
Имя
- должны указать: что
, и весь столбец
Мгновенное заполнение
(Фиксированной ширины) и столбец попадут датыSpace, кликнув по его (имен и других «;A1)-1)
нет надо из исходные и разделенные
Их мы и
ошибки. Для нас
способом разделенную ячейку,
office-guru.ru
4 способа разбить ячейки на части в программе Microsoft Excel
шапку таблицы, один «,A2,1)+1))Отчество нужно найти, где будет заполнен именами.» и заставить Excel нажмите прибытия.Чтобы изменить формат(Пробел) и заголовку, и, удерживая текстовых данных)Ячейка С2 формула: ниже… строки имеют разную
будем использовать для важно, чтобы эта
Разделение ячеек
как единый элемент. из разделов который,=ПСТР(A2;ПОИСК(» «;A2;1)+1;НАЙТИ(» «;A2;НАЙТИ(» «;A2;1)+1)-(НАЙТИ(«Фамилия нужно искать, а Очень умный инструмент, автоматически заполнять (вNext данных для каждогоComma нажатой левую кнопкуИнструмент « = =ПСТР (A1;НАЙТИТема — «обратная длину и разное разделения строк. статья была вамА вот, по диагонали
Способ 1: объединение ячеек
делится на два «;A2;1)+1))2 также позицию символа,
- не правда ли? нашем случае –
- (Далее). конкретного столбца, выделите(Запятая), а также мыши, протащите указательТекст по столбцам (» «;A1)+1;100) функция функции - количество символов. ИменноДопустим на лист Excel полезна. Просим вас можно разделить даже подраздела? В этомИзвлекаем отчество:Sally K. Brooke
- с которого следуетЕсли «Мгновенное заполнение» включено, разбивать) данные, приВ разделе его, кликнув по ставим галочку напротив вправо, чтобы выделить» действительно очень удобен,И текст читается: сцепить»; поэтому мы называли были импортированные данные уделить пару секунд обычную ячейку. случае, можно применить=RIGHT(A2,LEN(A2)- FIND(» «,A2,FIND(» «,A2,1)+1))
Sally начать поиск. В но не предлагает обнаружении определенной закономерности.Data preview нему в области
параметра нужное количество столбцов
Способ 2: разделение объединенных ячеек
когда нужно разделить Добрый деньвопрос — «функция такую формулу – из другой программы. и сообщить, помоглаКликаем правой кнопкой мыши небольшие хитрости.=ПРАВСИМВ(A2;ДЛСТР(A2)-НАЙТИ(» «;A2;НАЙТИ(» «;A2;1)+1))K.
- нашем примере никаких вариантов, которыеЕсли Вы ещё не(Образец разбора данных)Data previewTreat consecutive delimiters as (сколько хотите вставить). данные из одногоА как расцепить,
- обратная функции расцепить». гибкой, в начале Из-за несовместимости структуры ли она вам, по нужной ячейке,Для того, чтобы определенныеИзвлекаем фамилию:BrookeSEARCH(» «,A2,1) соответствуют определённому шаблону, знакомы с этой
настройте ширину столбцов.(Образец разбора данных), one Затем кликните правой столбца по нескольким разъединить текст или
Способ 3: разделение по диагонали путем форматирования
ps Экстрасенсов, телепатов статьи. Она подходит данных при импорте
- с помощью кнопок и в появившемся ячейки казались разделенными,=LEFT(A2,FIND(» «,A2,1)-2)Извлекаем имя:или Вы можете запустить функцией, я попробую Как видно на а затем установите(Считать последовательные разделители
- кнопкой мыши по в Excel 2013, предложение если в и прочих энтузазистов для любых условий
- некоторые значение из внизу страницы. Для контекстном меню выбираем следует объединить другие=ЛЕВСИМВ(A2;НАЙТИ(» «;A2;1)-2)=LEFT(A2,FIND(» «,A2,1)-1)ПОИСК(» «;A2;1) этот инструмент вручную кратко объяснить её рисунке ниже, край желаемый формат в одним). Этот параметр выделенной области и 2010, 2007 или
нём много слов прошу не шуметь при решении подобного разных категорий были удобства также приводим пункт ячейки таблицы.
Способ 4: разделение по диагонали через вставку фигуры
Как Вы понимаете, эти=ЛЕВСИМВ(A2;НАЙТИ(» «;A2;1)-1)говорит о том, на вкладке суть. Этот инструмент столбца символизирует вертикальная разделе
- поможет избежать лишнего в контекстном меню 2003. и символов по — может автор рода задач. Гибкость внесены в одну
- ссылку на оригинал«Формат ячеек…»Нужно хорошо продумать всю формулы работают неИзвлекаем отчество:
- что мы хотимData анализирует данные, которые линия, и чтобы
Column data format разбиения данных, например, выберите команду«Текст по столбцам» позволяет необходимой длине на сам определиться…{/post}{/quote} придает ей сложная ячейку. Необходимо из (на английском языке).
. Или же, набираем
lumpics.ru
Объединение и отмена объединения ячеек
структуру будущей таблицы. только для разделения=MID(A2,FIND(» «,A2,1)+1,FIND(» «,A2,FIND(» «,A2,1)+1)-(FIND(« найти символ пробела(Данные) > Вы вводите на задать край следующего(Формат данных столбца). когда между словамиInsert разбивать значения ячеек, две ячейкиПросто опечатка, обратная комбинация из функций этой ячейки отделитьНе удается разбить отдельные на клавиатуре сочетаниеНад тем местом на имён в Excel. «,A2,1)+1)) в ячейке
Flash Fill рабочий лист, и столбца, просто кликнитеНа этом же шаге есть 2 или(Вставить).
Объединение ячеек
-
отделённые разделителями, или
-
… функция функции СЦЕПИТЬ, НАЙТИ. Пользователю формулы
целые числовые значения. ячейки, но можно клавиш листе, где нужно Вы можете использовать=ПСТР(A2;НАЙТИ(» «;A2;1)+1;НАЙТИ(» «;A2;НАЙТИ(» «;A2;1)+1)-(НАЙТИ(«A2(Мгновенное заполнение) или пытается выяснить, откуда в нужном месте. мастера Вы можете более последовательных пробела.Результат будет примерно таким,
Отмена объединения ячеек
-
выделять данные фиксированной: Если правильно понял есть же пример достаточно определить закономерность Пример таких неправильно
-
отобразить его какCtrl+1
иметь разделенный элемент, их для разбиения
-
«;A2;1)+1))и начнём поиск нажав сочетание клавиш они взялись и Двойной щелчок по выбрать, в какойНастраиваем ограничитель строк что Вы видите ширины (когда всеC1 =ЛЕВСИМВ (A1;длина)
-
Аля и указать их импортированных данных отображен если бы ячейки. выделяем две соседние любых данных изИзвлекаем фамилию: с первого символа.
support.office.com
Как разделить текст по ячейкам формула в Excel
Ctrl+E существует ли в вертикальной линии удалит столбец поместить разделённые. Этот параметр может на рисунке ниже значения содержат определённоеC2 =ПРАВСИМВ (A1;: Спасибо в параметрах функций: ниже на рисунке: была разделена, объединениеВ открывшемся окне формата ячейки. Находясь во одного столбца по=RIGHT(A2,LEN(A2)- FIND(» «,A2,FIND(» «,A2,1)+1))Замечание:. них какая-либо закономерность. край столбца, а данные. Для этого понадобиться, если в (новые столбцы вставлены количество символов). Давайте
Как разделить текст на две ячейки Excel
ДЛСТР (A1)-длина)Serge будут это квадратныеСначала определим закономерность, по ячеек над ней. ячеек, переходим во вкладке нескольким. Например, следующие=ПРАВСИМВ(A2;ДЛСТР(A2)-НАЙТИ(» «;A2;НАЙТИ(» «;A2;1)+1))Если поиск начинаетсяСуществуют формулы, которые могут Как только «Мгновенное если Вам нужно кликните по иконке
столбце, который Вы слева от выделенных рассмотрим эти вариантыКак вариант: Я правда не скобки либо другие которой можно определить,Выделите ячейки для объединения. вкладку«Главная» формулы Вы можетеФункция с первого символа, быть очень полезны, заполнение» распознает Ваши переместить границу столбца выбора диапазона (в разбиваете, содержатся какие-либо столбцов): подробнее:
C2 =ПСТР (A1;нач_позиция; понял в одной
разделительные знаки. Например, что данные из
Выберите«Граница»
, ищем в блоке
Описание формулы для разделения текста по ячейкам:
использовать, чтобы разбитьMID Вы можете вообще когда возникает необходимость
- действия и вычислит в другое место, терминах Microsoft эта
- значения, заключённые вПримечание:Как разбить текст с кол_во_символов)
- ячейке нужен результат это могут быть разных категорий, несмотряОбъединить и поместить в
. инструментов текстовые данные, разделённые(ПСТР) – извлекает пропустить аргумент разбить ячейки или закономерность, Excel предложит просто перетащите вертикальную иконка называется кавычки или вЕсли у Вас разделителями по столбцампричем кол-во символов или в двух, пробелы если нужно на то, что центре.Около размещенного посередине окна«Выравнивание» запятыми: часть текстовой строкиstart_num столбцы с данными
вариант, и последовательность линию мышью. НаСвернуть диалоговое окно апострофы, и Вы нет столбцов, следующихКак выделить текстовые данные можно указывать больше, на всякий случай разделить строку на они находятся вВажно:«Надпись»на ленте кнопкуA (то есть заданное(нач_позиция) в формуле в Excel. На записей в новом самом деле, все) справа от поля хотите, чтобы такие непосредственно за тем, фиксированной величины чем длина строки оба варианта. слова и т.п.
одной и той В объединенной ячейкекликаем на одну«Объединить и поместить вB количество символов). Синтаксис: и упростить её самом деле, следующих столбце появится буквально эти инструкции подробноDestination участки текста не что Вы хотитеПредположим, есть список участников, — сам «обрежет»Да, и подойдётВ данном примере функция же строке. В отображается содержимое только из двух кнопок, центре»C=MID(text,start_num,num_chars) до такого вида: шести функций будет за мгновение. расписаны в верхней(Поместить в) и разбивались, а рассматривались
exceltable.com
обратная функция функции — сцепить
разбить, то необходимость приглашённых на конференцию
до конца. только для Вашего НАЙТИ во втором
нашем случае нас одной ячейки (верхней на которых изображена
. Жмем на неё.
D=ПСТР(текст;начальная_позиция;количество_знаков)
=LEFT(A2,SEARCH(» «,A2)-1)
достаточно в большинстве
Таким образом, при помощи части диалогового окна выберите крайний левый как цельные значения. в этом шаге
или какое-то другоеP.S: Уберите все примера, если чисел
аргументе определяет положение интересуют только числа,
левой ячейки для косая линия, наклоненнаяДля наглядности, чтобы лучше1В качестве аргументов функции
=ЛЕВСИМВ(A2;ПОИСК(» «;A2)-1) случаев – этого инструмента ВыТак как каждый ID столбец из тех,
Например, если Вы отпадает и его мероприятие. На рисунке
пробелы в формулах. будет больше ещё
относительно первой закрывающейся которые находятся вне языков с направлением справа налево, или видеть, что у
Полное обозначение указываем: какой текстLEFT
LEFT можете взять какую-то
товара содержит 9 в которые Вы выберите в качестве можно пропустить. Главное ниже видно, чтоВалентин б ДЛСТР надо использовать.
скобки. А в квадратных скобок. Каким письма слева направо слева направо. Выбираем нас получилось, установим
Штат взять, позицию символа,(ЛЕВСИМВ) и
(ЛЕВСИМВ), часть данных, находящихся символов, устанавливаем линию
хотите поместить разделённые разделителя запятую, а
не упустите, что в столбце
: Я подготовил вамSerge
третьем аргументе эта способом можно быстро или правой верхней нужный вариант. Тут границы. Выделяем весь
Аббревиатура
с которого нужно
RIGHT
MID
planetaexcel.ru
Как в Эксель Excel расцепить, разъединить текст или предложение из одной ячейки на две ячейки по необходимой длине
в одном или границы столбца на
данные. К сожалению, в качестве ограничителя пустых столбцов должноParticipant таблицы с использованием: Боюсь автор нас же функция вычисляет выбрать из строк ячейки для языков
же можно выбрать диапазон ячеек, которыйСтолица
начать, и сколько(ПРАВСИМВ) – возвращает(ПСТР), нескольких столбцах, и это значение, как невозможно импортировать разделённые
строк – кавычки быть не меньше,(Участник) перечислены имена
функций. Напишите письмо покинул… положение нужного нам
целые числа и с направлением письма тип и цвет планируем отвести под
2 символов извлечь.
левую или правуюRIGHT ввести их в
показано на рисунке данные на другой («), тогда любые
чем количество столбцов, участников, государство и
на п/я [email protected]Alex_ST текста в строке поместить их в справа налево). Данные линии. Когда выбор таблицу. В той
Alabama, AL, MontgomeryВы можете использовать аналогичные
часть текста из
(ПРАВСИМВ), новый столбец. Думаю,
выше.
лист или в слова, заключённые в
на которое вы ожидаемая дата прибытия: Я вышлю файл: в «Приёмах» на относительно второй открывающийся
отдельные ячейки? Эффективным в других объединенных
сделан, жмем на же вкладкеAlabama формулы, чтобы разбить заданной ячейки соответственно.FIND
Вы лучше поймёте
Раннее мы рассматривали возможность разделить текст по столбцам на примере деления ФИО на составные части. Для этого мы использовали инструмент в Excel «Текст по столбцам».
Несомненно, это очень важный и полезный и инструмент в Excel, который значительно может упростить множество задач. Но у данного способа есть небольшой недостаток. Если вам, например, постоянно присылают данные в определенном виде, а вам постоянно необходимо их делить, то это занимает определенное время, кроме того, если данные вам прислали заново, то вам снова нужно будет проделать все операции.
Содержание
- 1 Пример 1. Делим текст с ФИО по столбцам с помощью формул
- 1.1 Приступаем к делению первой части текста — Фамилии
- 1.2 Приступаем к делению второй части текста — Имя
- 1.3 Приступаем к делению третьей части текста — Отчество
- 2 Пример 2. Как разделить текст по столбцам в Excel с помощью формулы
Пример 1. Делим текст с ФИО по столбцам с помощью формул
Если рассматривать на примере деления ФИО, то разделить текст можно будет с помощью текстовых формул Excel, используя функцию ПСТР и НАЙТИ, которую мы рассматривали в прошлых статьях. В этом случае вам достаточно вставить данные в определенный столбец, а формулы автоматически разделят текст так как вам необходимо. Давайте приступит к рассмотрению данного примера.
У нас есть столбец со списком ФИО, наша задача разместить фамилию, имя отчество по отдельным столбцам.
Попробуем очень подробно описать план действия и разобьем решение задачи на несколько этапов.
Первым делом добавим вспомогательные столбцы, для промежуточных вычислений, чтобы вам было понятнее, а в конце все формулы объединим в одну.
Итак, добавим столбцы позиция 1-го и 2-го пробелам. С помощью функции НАЙТИ, как мы уже рассматривали в предыдущей статье найдем позицию первого пробелам. Для этого в ячейке «H2» пропишем формулу
=НАЙТИ(" ";A2;1)
и протянем вниз. Формулу объяснять не буду — смотрите предыдущую статью
Теперь нам необходимо найти порядковый номер второго пробела. Формула будет такая же, но с небольшим отличием. Если прописать такую же формулу, то функция найдет нам первый пробел, а нам нужен второй пробел. Значит на необходимо поменять третий аргумент в функции НАЙТИ — начальная позиция — то есть позиция с которой функция будет искать искомый текст. Мы видим, что второй пробел находится в любом случае после первого пробела, а позицию первого пробела мы уже нашли, значит прибавив 1 к позиции первого пробелам мы укажем функции НАЙТИ искать пробел начиная с первой буквы после первого пробела. Функция будет выглядеть следующим образом:
=НАЙТИ(" ";A2;H2+1)
Далее протягиваем формулу и получаем позиции 1-го и 2-го пробела.
Приступаем к делению первой части текста — Фамилии
Для этого мы воспользуемся функцией ПСТР, напомню синтаксис данной функции:
=ПСТР(текст; начальная_позиция; число_знаков), где
- текст — это ФИО, в нашем примере это ячейка A2;
- начальная_позиция — в нашем случае это 1, то есть начиная с первой буквы;
- число_знаков — мы видим, что фамилия состоит из всех знаков, начиная с первой буквы и до 1-го пробела. А позиция первого пробела нам уже известна. Это и будет количество знаков минус 1 знак самого пробела.
Формула будет выглядеть следующим образом:
=ПСТР(A2;1;H2-1)
Приступаем к делению второй части текста — Имя
Снова используем функцию =ПСТР(текст; начальная_позиция; число_знаков), где
- текст — это тот же текст ФИО, в нашем примере это ячейка A2;
- начальная_позиция — в нашем случае Имя начинается с первой буква после первого пробела, зная позицию этого пробела получаем H2+1;
- число_знаков — число знаков, то есть количество букв в имени. Мы видим, что имя у нас находится между двумя пробелами, позиции которых мы знаем. Если из позиции второго пробела отнять позицию первого пробела, то мы получим разницу, которая и будет равна количеству символов в имени, то есть I2-H2
Получаем итоговую формулу:
=ПСТР(A2;H2+1;I2-H2)
Приступаем к делению третьей части текста — Отчество
И снова функция =ПСТР(текст; начальная_позиция; число_знаков), где
- текст — это тот же текст ФИО, в нашем примере это ячейка A2;
- начальная_позиция — Отчество у нас находится после 2-го пробелам, значит начальная позиция будет равна позиции второго пробела плюс один знак или I2+1;
- число_знаков — в нашем случае после Отчества никаких знаков нет, поэтому мы просто может взять любое число, главное, чтобы оно было больше возможного количества символов в Отчестве, я взял цифру с большим запасом — 50
Получаем функцию
=ПСТР(A2;I2+1;50)
Далее выделяем все три ячейки и протягиваем формулы вниз и получаем нужный нам результат. На этом можно закончить, а можно промежуточные расчеты позиции пробелов прописать в сами формулы деления текста. Это очень просто сделать. Мы видим, что расчет первого пробела находится в ячейке H2 — НАЙТИ(» «;A2;1), а расчет второго пробела в ячейке I2 — НАЙТИ(» «;A2;H2+1) . Видим, что в формуле ячейки I2 встречается H2 меняем ее на саму формулу и получаем в ячейке I2 вложенную формулу НАЙТИ(» «;A2;НАЙТИ(» «;A2;1)+1)
Смотрим первую формулу выделения Фамилии и смотрим где здесь встречается H2 или I2 и меняем их на формулы в этих ячейках, аналогично с Именем и Фамилией
- Фамилия =ПСТР(A2;1;H2-1) получаем =ПСТР(A2;1;НАЙТИ(» «;A2;1)-1)
- Имя =ПСТР(A2;H2+1;I2—H2) получаем =ПСТР(A2;НАЙТИ(» «;A2;1)+1;
НАЙТИ(» «;A2;НАЙТИ(» «;A2;1)+1)—НАЙТИ(» «;A2;1)) - Отчество =ПСТР(A2;I2+1;50) получаем =ПСТР(A2;НАЙТИ(» «;A2;НАЙТИ(» «;A2;1)+1)+1;50)
Теперь промежуточные вычисления позиции пробелом можно смело удалить. Это один из приемов, когда для простоты сначала ищутся промежуточные данные, а потом функцию вкладывают одну в другую. Согласитесь, если писать такую большую формулу сразу, то легко запутаться и ошибиться.
Надеемся, что данный пример наглядно показал вам, как полезны текстовые функции Excel для работы с текстом и как они позволяют делить текст автоматически с помощью формул однотипные данные. Если вам понравилась статья, то будем благодарны за нажатие на +1 и мне нравится. Подписывайтесь и вступайте в нашу группу вконтакте.
Пример 2. Как разделить текст по столбцам в Excel с помощью формулы
Рассмотрим второй пример, который так же очень часто встречался на практике. Пример похож предыдущий, но данных которые нужно разделить значительно больше. В этом примере я покажу прием, который позволит достаточно быстро решить вопрос и не запутаться.
Допустим у нас есть список чисел, перечисленных через запятую, нам необходимо разбить текст таким образом, чтобы каждое число было в отдельной ячейке (вместо запятых это могут быть любые другие знаки, в том числе и пробелы). То есть нам необходимо разбить текст по словам.
Напомним, что вручную (без формул) это задача очень просто решается с помощью инструмента текст по столбцам, который мы уже рассматривали. В нашем же случае требуется это сделать с помощью формул.
Для начала необходимо найти общий разделить, по которому мы будет разбивать текст. В нашем случае это запятая, но например в первой задаче мы делили ФИО и разделитель был пробел. Наш второй пример более универсальный (более удобный при большом количестве данных), так например мы удобно могли бы делить не только ФИО по отдельным ячейкам, а целое предложение — каждое слово в отдельную ячейку. Собственно такой вопрос поступил в комментариях, поэтому было решено дополнить эту статью.
Для удобства в соседнем столбце укажем этот разделитель, чтобы не прописывать его в формуле а просто ссылаться на ячейку. Это так же позволит нам использовать файл для решения других задач, просто поменяв разделитель в ячейках.
Теперь основная суть приема.
Шаг 1. В вспомогательном столбце находим позицию первого разделителя с помощью функции НАЙТИ. Описывать подробно функцию не буду, так как мы уже рассматривали ее раннее. Пропишем формулу в D1 и протянем ее вниз на все строки
=НАЙТИ(B1;A1;1)
То есть ищем запятую, в тексте, начиная с позиции 1
Шаг 2. Далее в ячейке E1 прописываем формулу для нахождения второго знака (в нашем случае запятой). Формула аналогичная, но с небольшими изменениями.
=НАЙТИ($B1;$A1;D1+1)
Во-первых: закрепим столбец искомого значения и текста, чтобы при протягивании формулы вправо ссылки на ячейки не сдвигалась. Для этого нужно написать доллар перед столбцом B и A — либо вручную, либо выделить A1 и B1, нажать три раза клавишу F4, после этого ссылки станут не относительными, а абсолютными.
Во-вторых: третий аргумент — начало позиции мы рассчитаем как позиция предыдущего разделителя (мы его нашли выше) плюс 1 то есть D1+1 так как мы знаем, что второй разделитель точно находится после первого разделителя и нам его не нужно учитывать.
Пропишем формулу и протянем ее вниз.
Шаг 3. Находимо позиции всех остальных разделителей. Для этого формулу нахождения второго разделителя (шаг 2) протянем вправо на то количество ячеек, сколько всего может быть отдельно разбитых значений с небольшим запасом. Получим все позиции разделителей. Там где ошибка #Знач означает что значения закончились и формула больше не находит разделителей. Получаем следующее
Шаг 4. Отделяем первое число от текст с помощью функции ПСТР.
=ПСТР(A1;1;D1-1)
Начальная позиция у нас 1, количество знаков мы рассчитываем как позиция первого разделителя минус 1: D1-1 протягиваем формулу вниз
Шаг 5. Находимо второе слово так же с помощью функции ПСТР в ячейке P1
=ПСТР($A1;D1+1;E1-D1-1)
Начальная позиция второго числа у нас начинается после первой запятой. Позиция первой запятой у нас есть в ячейке D1, прибавим единицу и получим начальную позицию нашего второго числа.
Количество знаков это есть разница между позицией третьего разделителя и второго и минус один знак, то есть E1-D1-1
Закрепим столбец A исходного текста, чтобы он не сдвигался при протягивании формулы право.
Шаг 6. Протянем формулу полученную на шаге 5 вправо и вниз и получим текст в отдельных ячейках.
Шаг 7. В принципе задача наша уже решена, но для красоты все в той же ячейке P1 пропишем формула отлавливающую ошибку заменяя ее пустым значением. Так же можно сгруппировать и свернуть вспомогательные столбцы, чтобы они не мешали. Получим итоговое решение задачи
=ЕСЛИОШИБКА(ПСТР($A1;D1+1;E1-D1-1);»»)
Примечание. Первую позицию разделителя и первое деление слова мы делали отлично от других и из-за этого могли протянуть формулу только со вторых значений. Во время написания задачи я заметил, что можно было бы упростить задачу. Для этого в столбце С нужно было прописать 0 значения первого разделителя. После этого находим значение первого разделителя
=НАЙТИ($B1;$A1;C1+1)
а первого текста как
=ПСТР($A1;C1+1;D1-C1-1)
После этого можно сразу протягивать формулу на остальные значения. Именно этот вариант оставляю как пример для скачивания. В принципе файлом можно пользоваться как шаблоном. В столбец «A» вставляете данные, в столбце «B» указываете разделитель, протягиваете формулы на нужное количество ячеек и получаете результат.
Внимание! В комментариях заметили, что так как в конце текста у нас нет разделителя, то у нас не считается количество символов от последнего разделителя до конца строки, поэтому последний разделенный текст отсутствует. Чтобы решить вопрос можно либо на первом шаге добавить вспомогательный столбец радом с исходным текстом, где сцепить этот текст с разделителем. Таким образом у нас получится что на конце текста будет разделитель, значит наши формулы посчитают его позицию и все будет работать.
Либо второе решение — это на шаге 3, когда мы составляем формулу вычисления позиций разделителей дополнить ее. Сделать проверку, если ошибка, то указываем заведомо большое число, например 1000.
=ЕСЛИОШИБКА(НАЙТИ($B1;$A1;C1+1);1000)
Таким образом последний текст будет рассчитываться начиная от последней запятой до чуть меньше 1000 знаков, то есть до конца строки, что нам и требуется.
Оба варианта выложу для скачивания.
Скачать пример: Как разделить текст по столбцам с помощью функции_1.xlsx (исправлено: доп поле)
Скачать пример: Как разделить текст по столбцам с помощью функции_2.xlsx (исправлено: заведомо большое число)
В этой статье Вы найдёте несколько способов, как разбить ячейки или целые столбцы в Excel 2010 и 2013. Приведённые примеры и скриншоты иллюстрируют работу с инструментами «Текст по столбцам» и «Мгновенное заполнение», кроме этого Вы увидите подборку формул для разделения имён, текстовых и числовых значений. Этот урок поможет Вам выбрать наилучший метод разбиения данных в Excel.
Говоря в общем, необходимость разбить ячейки в Excel может возникнуть в двух случаях: Во-первых, при импорте информации из какой-либо внешней базы данных или с веб-страницы. При таком импорте все записи копируются в один столбец, а нужно, чтобы они были помещены в разных столбцах. Во-вторых, при разбиении уже существующей таблицы, чтобы получить возможность качественнее настроить работу фильтра, сортировку или для более детального анализа.
- Разбиваем ячейки при помощи инструмента «Текст по столбцам»
- Как разбить объединённые ячейки в Excel
- Разделяем данные в Excel 2013 при помощи инструмента «Мгновенное заполнение»
- Формулы для разбиения столбцов (имен и других текстовых данных)
Содержание
- Разбиваем ячейки в Excel при помощи инструмента «Текст по столбцам»
- Разбиваем текстовые данные с разделителями по столбцам в Excel
- Разбиваем текст фиксированной ширины по нескольким столбцам
- Разбиваем объединённые ячейки в Excel
- Разделяем данные на несколько столбцов в Excel 2013 при помощи мгновенного заполнения
- Как в Excel разбивать ячейки при помощи формул
- Пример 1
- Пример 2
- Пример 3
- Пример 4
- Пример 5
Разбиваем ячейки в Excel при помощи инструмента «Текст по столбцам»
Инструмент «Текст по столбцам» действительно очень удобен, когда нужно разделить данные из одного столбца по нескольким в Excel 2013, 2010, 2007 или 2003.
«Текст по столбцам» позволяет разбивать значения ячеек, отделённые разделителями, или выделять данные фиксированной ширины (когда все значения содержат определённое количество символов). Давайте рассмотрим эти варианты подробнее:
- Как разбить текст с разделителями по столбцам
- Как выделить текстовые данные фиксированной величины
Разбиваем текстовые данные с разделителями по столбцам в Excel
Предположим, есть список участников, приглашённых на конференцию или какое-то другое мероприятие. На рисунке ниже видно, что в столбце Participant (Участник) перечислены имена участников, государство и ожидаемая дата прибытия:
Необходимо разбить этот текст на отдельные столбцы, чтобы таблица имела следующие данные (слева направо): First Name (Имя), Last Name (Фамилия), Country (Страна), Arrival Date (Ожидаемая дата прибытия) и Status (Статус).
- Если в таблице есть хотя бы один столбец справа от столбца, который необходимо разбить, тогда первым делом создайте новые пустые столбцы, в которые будут помещены полученные данные. Этот шаг необходим для того, чтобы результаты не были записаны поверх уже существующих данных.В нашем примере сразу после столбца Participant находится столбец Status, и мы собираемся добавить между ними новые столбцы Last Name, Country и Arrival Date.Если кто-то забыл, я напомню быстрый способ вставить сразу несколько столбцов на лист Excel. Для этого выберите столбец Status, кликнув по его заголовку, и, удерживая нажатой левую кнопку мыши, протащите указатель вправо, чтобы выделить нужное количество столбцов (сколько хотите вставить). Затем кликните правой кнопкой мыши по выделенной области и в контекстном меню выберите команду Insert (Вставить).
Результат будет примерно таким, что Вы видите на рисунке ниже (новые столбцы вставлены слева от выделенных столбцов):
Примечание: Если у Вас нет столбцов, следующих непосредственно за тем, что Вы хотите разбить, то необходимость в этом шаге отпадает и его можно пропустить. Главное не упустите, что пустых столбцов должно быть не меньше, чем количество столбцов, на которое вы хотите разделить данные.
- Выделите столбец, который требуется разбить. Затем откройте вкладку Data (Данные) > Data Tools (Работа с данными) > Text to Columns (Текст по столбцам).
- Откроется диалоговое окно Convert Text to Columns wizard (Мастер распределения текста по столбцам). На первом шаге мастера Вы выбираете формат данных. Так как записи разделены пробелами и запятыми, мы выбираем формат Delimited (С разделителями). Вариант Fixed width (Фиксированной ширины) будет рассмотрен чуть позже. Если все готово, жмите Next (Далее), чтобы продолжить.
- На следующем шаге определяем разделители, которые содержатся в данных, и ограничитель строк.
- Настраиваем разделители. Если данные разделены одним или несколькими разделителями, то нужно выбрать все подходящие варианты в разделе Delimiters (Символом-разделителем является) или ввести свой вариант разделителя в поле Other (Другой).В нашем примере мы выбираем Space (Пробел) и Comma (Запятая), а также ставим галочку напротив параметра Treat consecutive delimiters as one (Считать последовательные разделители одним). Этот параметр поможет избежать лишнего разбиения данных, например, когда между словами есть 2 или более последовательных пробела.
- Настраиваем ограничитель строк. Этот параметр может понадобиться, если в столбце, который Вы разбиваете, содержатся какие-либо значения, заключённые в кавычки или в апострофы, и Вы хотите, чтобы такие участки текста не разбивались, а рассматривались как цельные значения. Например, если Вы выберите в качестве разделителя запятую, а в качестве ограничителя строк – кавычки («), тогда любые слова, заключённые в кавычки (например, «California, USA»), будут помещены в одну ячейку. Если же в качестве ограничителя строк установить значение None (Нет), тогда слово «California» будет помещено в один столбец, а «USA» – в другой.
В нижней части диалогового окна находится область Data preview (Образец разбора данных). Прежде чем нажать Next (Далее) будет разумным пролистать это поле и убедиться, что Excel правильно распределил все данные по столбцам.
- Настраиваем разделители. Если данные разделены одним или несколькими разделителями, то нужно выбрать все подходящие варианты в разделе Delimiters (Символом-разделителем является) или ввести свой вариант разделителя в поле Other (Другой).В нашем примере мы выбираем Space (Пробел) и Comma (Запятая), а также ставим галочку напротив параметра Treat consecutive delimiters as one (Считать последовательные разделители одним). Этот параметр поможет избежать лишнего разбиения данных, например, когда между словами есть 2 или более последовательных пробела.
- Осталось сделать всего две вещи – выбрать формат данных и указать, куда поместить разделённые ячейки.В разделе Column data format (Формат данных столбца) Вы можете выбрать формат данных отдельно для каждого столбца, в которые будут помещены разделённые данные. По умолчанию для всех столбцов задан формат General (Общий). Мы оставим его без изменений для первых трёх столбцов, а для четвёртого столбца установим формат Data (Дата), что логично, ведь в этот столбец попадут даты прибытия.Чтобы изменить формат данных для каждого конкретного столбца, выделите его, кликнув по нему в области Data preview (Образец разбора данных), а затем установите желаемый формат в разделе Column data format (Формат данных столбца).
На этом же шаге мастера Вы можете выбрать, в какой столбец поместить разделённые данные. Для этого кликните по иконке выбора диапазона (в терминах Microsoft эта иконка называется Свернуть диалоговое окно) справа от поля Destination (Поместить в) и выберите крайний левый столбец из тех, в которые Вы хотите поместить разделённые данные. К сожалению, невозможно импортировать разделённые данные на другой лист или в другую рабочую книгу, попытка сделать это приведёт к сообщению об ошибке выбора конечной ссылки.
Совет: Если Вы не хотите импортировать какой-то столбец (столбцы), который показан в области Data preview (Образец разбора данных), то выделите его и выберите вариант Do not import column (Пропустить столбец) в разделе Column data format (Формат данных столбца).
- Нажмите Finish (Готово)!
Разбиваем текст фиксированной ширины по нескольким столбцам
Если данные состоят из текстовых или числовых значений с фиксированным количеством символов, Вы можете разбить их на несколько столбцов следующим способом.
К примеру, есть список товаров с ID и наименованием, причем идентификатор товара – это 9 символов, которые стоят перед наименованием этого товара:
Вот что Вам нужно сделать, чтобы разбить такой столбец на два:
- Запустите инструмент Text to Columns (Текст по столбцам), как мы это делали в предыдущем примере. На первом шаге мастера выберите параметр Fixed width (Фиксированной ширины) и нажмите Next (Далее).
- В разделе Data preview (Образец разбора данных) настройте ширину столбцов. Как видно на рисунке ниже, край столбца символизирует вертикальная линия, и чтобы задать край следующего столбца, просто кликните в нужном месте. Двойной щелчок по вертикальной линии удалит край столбца, а если Вам нужно переместить границу столбца в другое место, просто перетащите вертикальную линию мышью. На самом деле, все эти инструкции подробно расписаны в верхней части диалогового окна 🙂
Так как каждый ID товара содержит 9 символов, устанавливаем линию границы столбца на это значение, как показано на рисунке выше.
- На следующем шаге выберите формат данных и укажите ячейки, куда поместить результат, как это было сделано в предыдущем примере, а затем нажмите Finish (Готово).
Разбиваем объединённые ячейки в Excel
Если Вы объединили несколько ячеек на листе Excel и теперь хотите вновь разбить их по отдельным столбцам, откройте вкладку Home (Главная) и в группе команд Alignment (Выравнивание) нажмите маленькую чёрную стрелку рядом с кнопкой Merge & Center (Объединить и поместить в центре). Далее из выпадающего списка выберите Unmerge Cells (Отменить объединение ячеек).
Таким образом объединение ячеек будет отменено, но удовольствие от результата будет испорчено тем, что все данные останутся в левом столбце. Думаю, Вы догадались, что нужно снова использовать функцию Text to Columns (Текст по столбцам), чтобы разбить данные из одного столбца на два или более столбцов.
Разделяем данные на несколько столбцов в Excel 2013 при помощи мгновенного заполнения
Если Вы уже обновились до Excel 2013, то можете воспользоваться преимуществами нового инструмента «Мгновенное заполнение» и заставить Excel автоматически заполнять (в нашем случае – разбивать) данные, при обнаружении определенной закономерности.
Если Вы ещё не знакомы с этой функцией, я попробую кратко объяснить её суть. Этот инструмент анализирует данные, которые Вы вводите на рабочий лист, и пытается выяснить, откуда они взялись и существует ли в них какая-либо закономерность. Как только «Мгновенное заполнение» распознает Ваши действия и вычислит закономерность, Excel предложит вариант, и последовательность записей в новом столбце появится буквально за мгновение.
Таким образом, при помощи этого инструмента Вы можете взять какую-то часть данных, находящихся в одном или нескольких столбцах, и ввести их в новый столбец. Думаю, Вы лучше поймёте о чём я говорю из следующего примера.
Первым делом, убедитесь, что инструмент «Мгновенное заполнение» включен. Вы найдёте этот параметр на вкладке File (Файл) > Options (Параметры) > Advanced (Дополнительно) > Automatically Flash Fill (Автоматически выполнять мгновенное заполнение).
Теперь давайте посмотрим, как можно автоматически разбить данные по ячейкам. Итак, Вы включили инструмент «Мгновенное заполнение», и начинаете вводить с клавиатуры данные, которые нужно поместить в отдельные ячейки. По мере ввода Excel будет пытаться распознать шаблон в вводимых значениях, и как только он его распознает, данные автоматически будут вставлены в остальные ячейки. Чтобы понять, как это работает, посмотрите на рисунок ниже:
Как видите, я ввёл только пару имён в столбец B, и «Мгновенное заполнение» автоматически заполнило остальные ячейки именами из столбца A. Если вы довольны результатом, просто нажмите Enter, и весь столбец будет заполнен именами. Очень умный инструмент, не правда ли?
Если «Мгновенное заполнение» включено, но не предлагает никаких вариантов, которые соответствуют определённому шаблону, Вы можете запустить этот инструмент вручную на вкладке Data (Данные) > Flash Fill (Мгновенное заполнение) или нажав сочетание клавиш Ctrl+E.
Как в Excel разбивать ячейки при помощи формул
Существуют формулы, которые могут быть очень полезны, когда возникает необходимость разбить ячейки или столбцы с данными в Excel. На самом деле, следующих шести функций будет достаточно в большинстве случаев – LEFT (ЛЕВСИМВ), MID (ПСТР), RIGHT (ПРАВСИМВ), FIND (НАЙТИ), SEARCH (ПОИСК) и LEN (ДЛСТР). Далее в этом разделе я кратко объясню назначение каждой из этих функций и приведу примеры, которые Вы сможете использовать в своих книгах Excel.
Пример 1
Самая распространённая ситуация, когда могут понадобится эти формулы – это необходимость разделить имена из одного столбца по нескольким. На рисунке ниже показано, какого результата мы пытаемся достичь:
Вы легко сможете разбить такие имена на два столбца при помощи следующих формул:
- Извлекаем имя (столбец First name):
=LEFT(A2,SEARCH(" ",A2,1)-1)
=ЛЕВСИМВ(A2;ПОИСК(" ";A2;1)-1)
- Извлекаем фамилию (столбец Last name):
=RIGHT(A2,LEN(A2)-SEARCH(" ",A2,1))
=ПРАВСИМВ(A2;ДЛСТР(A2)-ПОИСК(" ";A2;1))
Для тех, кому интересно, что означают эти формулы, я попробую объяснить более подробно.
SEARCH (ПОИСК) или FIND (НАЙТИ) – это абсолютно идентичные функции, которые выполняют поиск позиции определенной текстовой строки в заданной ячейке. Синтаксис формулы:
=SEARCH(find_text,within_text,[start_num])
=ПОИСК(искомый_текст;текст_для_поиска;[нач_позиция])
В качестве аргументов Вы должны указать: что нужно найти, где нужно искать, а также позицию символа, с которого следует начать поиск. В нашем примере SEARCH(» «,A2,1) или ПОИСК(» «;A2;1) говорит о том, что мы хотим найти символ пробела в ячейке A2 и начнём поиск с первого символа.
Замечание: Если поиск начинается с первого символа, Вы можете вообще пропустить аргумент start_num (нач_позиция) в формуле и упростить её до такого вида:
=LEFT(A2,SEARCH(" ",A2)-1)
=ЛЕВСИМВ(A2;ПОИСК(" ";A2)-1)
LEFT (ЛЕВСИМВ) и RIGHT (ПРАВСИМВ) – возвращает левую или правую часть текста из заданной ячейки соответственно. Синтаксис формулы:
=LEFT(text,[num_chars])
=ЛЕВСИМВ(текст;[количество_знаков])
В качестве аргументов указываем: какой текст взять и сколько символов извлечь. В следующем примере формула будет извлекать левую часть текста из ячейки A2 вплоть до позиции первого найденного пробела.
=LEFT(A2,SEARCH(" ",A2)-1)
=ЛЕВСИМВ(A2;ПОИСК(" ";A2)-1)
LEN (ДЛСТР) – считает длину строки, то есть количество символов в заданной ячейке. Синтаксис формулы:
=LEN(text)
=ДЛСТР(текст)
Следующая формула считает количество символов в ячейке A2:
=LEN(A2)
=ДЛСТР(A2)
Если имена в Вашей таблице содержат отчества или суффиксы, то потребуются немного более сложные формулы с использованием функции MID (ПСТР).
Пример 2
Вот такие формулы нужно использовать, когда имена, которые требуется разбить, содержат отчество или только один инициал отчества посередине.
A | B | C | D | |
1 | Полное имя | Имя | Отчество | Фамилия |
2 | Sally K. Brooke | Sally | K. | Brooke |
- Извлекаем имя:
=LEFT(A2,FIND(" ",A2,1)-1)
=ЛЕВСИМВ(A2;НАЙТИ(" ";A2;1)-1)
- Извлекаем отчество:
=MID(A2,FIND(" ",A2,1)+1,FIND(" ",A2,FIND(" ",A2,1)+1)-(FIND(" ",A2,1)+1))
=ПСТР(A2;НАЙТИ(" ";A2;1)+1;НАЙТИ(" ";A2;НАЙТИ(" ";A2;1)+1)-(НАЙТИ(" ";A2;1)+1))
- Извлекаем фамилию:
=RIGHT(A2,LEN(A2)- FIND(" ",A2,FIND(" ",A2,1)+1))
=ПРАВСИМВ(A2;ДЛСТР(A2)-НАЙТИ(" ";A2;НАЙТИ(" ";A2;1)+1))
Функция MID (ПСТР) – извлекает часть текстовой строки (то есть заданное количество символов). Синтаксис:
=MID(text,start_num,num_chars)
=ПСТР(текст;начальная_позиция;количество_знаков)
В качестве аргументов функции указываем: какой текст взять, позицию символа, с которого нужно начать, и сколько символов извлечь.
Пример 3
Вы можете использовать аналогичные формулы, чтобы разбить имена с суффиксами в конце:
A | B | C | D | |
1 | Полное имя | Имя | Фамилия | Суффикс |
2 | Robert Furlan Jr. | Robert | Furlan | Jr. |
- Извлекаем имя:
=LEFT(A2,FIND(" ",A2,1)-1)
=ЛЕВСИМВ(A2;НАЙТИ(" ";A2;1)-1)
- Извлекаем фамилию:
=MID(A2,FIND(" ",A2,1)+1,FIND(" ",A2,FIND(" ",A2,1)+1)-(FIND(" ",A2,1)+1))
=ПСТР(A2;НАЙТИ(" ";A2;1)+1;НАЙТИ(" ";A2;НАЙТИ(" ";A2;1)+1)-(НАЙТИ(" ";A2;1)+1))
- Извлекаем суффикс:
=RIGHT(A2,LEN(A2)-FIND(" ",A2,FIND(" ",A2,1)+1))
=ПРАВСИМВ(A2;ДЛСТР(A2)-НАЙТИ(" ";A2;НАЙТИ(" ";A2;1)+1))
Пример 4
А вот формулы, позволяющие разбить имена с фамилией, стоящей впереди и отделенной от имени запятой, и отчеством, находящимся в конце:
A | B | C | D | |
1 | Полное имя | Имя | Отчество | Фамилия |
2 | White, David Mark | David | Mark | White |
- Извлекаем имя:
=MID(A2,SEARCH(" ",A2,1)+1,FIND(" ",A2,FIND(" ",A2,1)+1)-(FIND(" ",A2,1)+1))
=ПСТР(A2;ПОИСК(" ";A2;1)+1;НАЙТИ(" ";A2;НАЙТИ(" ";A2;1)+1)-(НАЙТИ(" ";A2;1)+1))
- Извлекаем отчество:
=RIGHT(A2,LEN(A2)- FIND(" ",A2,FIND(" ",A2,1)+1))
=ПРАВСИМВ(A2;ДЛСТР(A2)-НАЙТИ(" ";A2;НАЙТИ(" ";A2;1)+1))
- Извлекаем фамилию:
=LEFT(A2,FIND(" ",A2,1)-2)
=ЛЕВСИМВ(A2;НАЙТИ(" ";A2;1)-2)
Пример 5
Как Вы понимаете, эти формулы работают не только для разделения имён в Excel. Вы можете использовать их для разбиения любых данных из одного столбца по нескольким. Например, следующие формулы Вы можете использовать, чтобы разбить текстовые данные, разделённые запятыми:
A | B | C | D | |
1 | Полное обозначение | Штат | Аббревиатура | Столица |
2 | Alabama, AL, Montgomery | Alabama | AL | Montgomery |
- Извлекаем название штата:
=LEFT(A2,SEARCH(",",A2)-1)
=ЛЕВСИМВ(A2;ПОИСК(",";A2)-1)
- Извлекаем аббревиатуру штата:
=MID(A2,SEARCH(",",A2)+2,SEARCH(",",A2,SEARCH(",",A2)+2)-SEARCH(",",A2)-2)
=ПСТР(A2;ПОИСК(",";A2)+2;ПОИСК(",";A2;ПОИСК(",";A2)+2)-ПОИСК(",";A2)-2)
- Извлекаем столицу штата:
=RIGHT(A2,LEN(A2)-(SEARCH(",",A2,SEARCH(",",A2)+1)+1))
=ПРАВСИМВ(A2;ДЛСТР(A2)-(ПОИСК(",";A2;ПОИСК(",";A2)+1)+1))
А вот пример реальных данных из Excel 2010. Данные из первого столбца разбиты на три отдельных столбца:
Оцените качество статьи. Нам важно ваше мнение: