Рассмотрим простой способ подсчета количества слов в ячейке в Excel.
Стандартной формулы подсчета слов в ячейке в Excel нет, поэтому итоговая формула будет состоять из нескольких формул. Итоговая формула выглядит следующим образом:
Краткое описание используемых функций (с подробным описанием можно ознакомиться в конце статьи):
СЖПРОБЕЛЫ — удаляет из текста лишние пробелы;
ПОДСТАВИТЬ — производит замену старого текста на новый в текстовой строке;
ДЛСТР — рассчитывает количество знаков в строке;
ЕПУСТО — проверяет является ли ячейка пустой.
Алгоритм подсчета
Алгоритм строится на том факте, что количество слов в любой фразе всегда на 1 больше, чем количество пробелов. Однако фраза может начинаться с пробела или по ошибке могут встречать двойные пробелы, поэтому в первую очередь удалим лишние проблемы из исходной фразы с помощью функции СЖПРОБЕЛЫ и подсчитаем длину фразы функцией ДЛСТР:
Теперь рассчитаем длину фразы без учета пробелов, для этого воспользуемся функций ПОДСТАВИТЬ, которая удалит символ пробела (если быть точнее, то заменит » » на «»):
Рассчитываем разницу между двумя данными значениями, прибавляем 1 и получаем итоговое количество слов в ячейке:
Однако в случае, если ячейка пустая, то данная формула вернет значение 1, поэтому добавим в функцию проверку на непустую ячейку (если ячейка пустая, то вернется значение 0):
СЖПРОБЕЛЫ(текст) Удаляет из текста лишние пробелы (кроме одиночных пробелов между словами).
Текст(обязательный аргумент) — текст, из которого удаляются лишние пробелы.
Функция ПОДСТАВИТЬ:
ПОДСТАВИТЬ(текст; стар_текст; нов_текст; [номер_вхождения]) Заменяет новым текстом старый текст в текстовой строке.
Текст(обязательный аргумент) — текст, в котором происходит подстановка;
Старый текст(обязательный аргумент) — заменяемый текст;
Новый текст(обязательный аргумент) — текст, на который меняется старый текст;
Номер вхождения(необязательный аргумент) — номер вхождения заменяемого фрагмента старый текст.
Функция ДЛСТР:
ДЛСТР(текст) Возвращает количество знаков в текстовой строке.
Текст(обязательный аргумент) — измеряемый текст.
Функция ЕПУСТО:
ЕПУСТО(значение) Проверяет, ссылается ли данная ссылка на пустую ячейку, и возвращает значение ИСТИНА или ЛОЖЬ.
Как посчитать количество слов в Excel
Пользователи Microsoft Word знают, на сколько полезна возможность узнать количество слов в набранном тексте. Однако, пользуясь Excel, узнать количество слов в документе не возможно штатными средствами.
В этой статье мы разберем, как с помощью формул посчитать количество слов в одной или нескольких ячейках.
Как посчитать количество слов в ячейке Excel
Для подсчета количества слов в ячейке нам потребуются функции ДЛСТР и ПОДСТАВИТЬ . Формула для учета количества слов будет выглядеть так:
Используя эту формулу для любой ячейки, вы получите значение количества слов, находящихся в ней.
Как эта формула работает?
Прежде чем мы погрузимся в то, как работает формула, предлагаю поразмышлять.
Если мы составим обычное предложение из 8 слов, то их будут разделять 7 пробелов.
Это означает, что в любом предложении слов на один больше чем пробелов. То есть, для того, чтобы посчитать количество слов в предложении, нам нужно рассчитать количество пробелов и прибавить к этому числу один.
В указанной выше формуле А1:А10 это диапазон ячеек в рамках которого мы хотим посчитать количество слов.
Как эта формула работает?
Эта формула работает по тому же принципу, что и для подсчета количества слов в одной ячейке. Разница лишь в использовании функции СУММПРОИЗВ . Она помогает нам вычислить количество слов во всем массиве данных.
Всякий раз, когда вы вводите текст в ячейку или диапазон ячеек, эти методы позволяют посчитать количество слов.
Я надеюсь, что в будущем Excel получит штатную возможность для подсчета слов.
Уверен, эти приемы помогут вам стать лучше в Excel.
Формула подсчета слов в ячейке excel
Но все-таки было бы очень неплохо, если бы Вы прикладывали СВОЙ файл Как? Написано в правилах форума.
Но все-таки было бы очень неплохо, если бы Вы прикладывали СВОЙ файл Как? Написано в правилах форума. _Boroda_
Но все-таки было бы очень неплохо, если бы Вы прикладывали СВОЙ файл Как? Написано в правилах форума. Автор — _Boroda_ Дата добавления — 26.06.2012 в 15:05
Serge_007
Дата: Вторник, 26.06.2012, 15:06 | Сообщение № 8
А если нет других слов, кроме «согласие» и «отказ», то пойдёт простая =СЧЁТЗ(A1:A16)
А если нет других слов, кроме «согласие» и «отказ», то пойдёт простая =СЧЁТЗ(A1:A16) Serge_007
Яндекс-деньги:41001419691823 | WMR:126292472390
Ответить
А если нет других слов, кроме «согласие» и «отказ», то пойдёт простая =СЧЁТЗ(A1:A16) Автор — Serge_007 Дата добавления — 26.06.2012 в 15:06
RAN
Дата: Вторник, 26.06.2012, 15:07 | Сообщение № 9
Ну если одной формулой и в одной ячейке, тады ой!
Ну если одной формулой и в одной ячейке, тады ой!
Быть или не быть, вот в чем загвоздка!
Ответить
Ну если одной формулой и в одной ячейке, тады ой!
=СЧЁТЗ(G1:G10)-СЧЁТЕСЛИ(G1:G10;»согласие») &» . «& СЧЁТЕСЛИ(G1:G10;»согласие») Автор — RAN Дата добавления — 26.06.2012 в 15:07
Гость
Дата: Вторник, 26.06.2012, 16:00 | Сообщение № 10
anger47
Дата: Вторник, 26.06.2012, 16:05 | Сообщение № 11
Гость
Дата: Вторник, 26.06.2012, 16:21 | Сообщение № 12
Гость
Дата: Вторник, 26.06.2012, 16:33 | Сообщение № 13
anger47
Дата: Вторник, 26.06.2012, 16:35 | Сообщение № 14
Serge_007
Дата: Вторник, 26.06.2012, 16:36 | Сообщение № 15
Повторю вопрос уважаемого _Boroda_,
Повторю вопрос уважаемого _Boroda_,
Яндекс-деньги:41001419691823 | WMR:126292472390
Ответить
Повторю вопрос уважаемого _Boroda_,
anger47
Дата: Вторник, 26.06.2012, 16:37 | Сообщение № 16
Swettlanka
Дата: Вторник, 26.06.2012, 16:51 | Сообщение № 17
anger47
Дата: Вторник, 26.06.2012, 17:04 | Сообщение № 18
MCH
Дата: Вторник, 26.06.2012, 17:06 | Сообщение № 19
У Вас в основном в ячейках текст «1/1», «1/2», «1/3», «1/4» а в ячейках N47 и N102 — числа (0,5 и 0,333333. ), которые выглядят как дробь
Предварительно установите формат ячеек в столбце N — текстовый и введите в данные ячейки 1/2 и 1/3 соответственно
У Вас в основном в ячейках текст «1/1», «1/2», «1/3», «1/4» а в ячейках N47 и N102 — числа (0,5 и 0,333333. ), которые выглядят как дробь
Предварительно установите формат ячеек в столбце N — текстовый и введите в данные ячейки 1/2 и 1/3 соответственно MCH
У Вас в основном в ячейках текст «1/1», «1/2», «1/3», «1/4» а в ячейках N47 и N102 — числа (0,5 и 0,333333. ), которые выглядят как дробь
Предварительно установите формат ячеек в столбце N — текстовый и введите в данные ячейки 1/2 и 1/3 соответственно Автор — MCH Дата добавления — 26.06.2012 в 17:06
Как подсчитать количество повторений
В этой статье я хочу рассказать, как можно подсчитать количество повторений какого-либо значения в таблице или в ячейке. Начнем по порядку. Имеется таблица: И необходимо подсчитать количество повторений каждого наименования: Как ни странно, но сделать это весьма просто: в Excel имеется функция — СЧЁТЕСЛИ, при помощи которой все это сделать можно буквально за секунды. Если количество повторений каждого наименования необходимо вывести в столбец В таблицы, а сами наименования расположены в столбце А: =СЧЁТЕСЛИ( $A$2:$A$30 ; A2 ) Диапазон ( $A$2:$A$30 ) — указываются ячейки диапазона, в которых записаны значения, количество которых необходимо подсчитать. Главная особенность: данный аргумент может быть исключительно ссылкой на ячейку или диапазон ячеек. Недопустимо указывать произвольный массив значений. Критерий ( A2 ) — указывается ссылка на ячейку или непосредственно значение для подсчета. Т.е. можно указать и так: =СЧЁТЕСЛИ( $A$2:$A$30 ;»Яблоко») . Помимо этого можно применять символы подстановки: ? и *. Т.е. указав в качестве Критерия «*банан*» можно подсчитать количество ячеек, в которых встречается слово «банан» (банановый, банан, бананы, банановый сок, сто бананов, три банана и орех и т.п.). А указав «банан*» — значения, начинающиеся на «банан» (бананы, банановый сок, банановая роща и т.п.). «?» — заменяет лишь один символ, т.е. указав «бан?н» можно подсчитать строки и со значением «банан» и со значением «банон» и т.д. Если в качестве критерия указать =СЧЁТЕСЛИ( $A$2:$A$30 ;»*») , то будут подсчитаны все текстовые значения. Числовые значения при этом игнорируются. Данные подстановочные символы (* и ?) не получится применить к числовым значениям — исключительно к тексту. Т.е. если если указать в качестве критерия «12*», то числа 1234, 123, 120 и т.п. не будут подсчитаны. Для подсчета числовых значений следует применять операторы сравнения: =СЧЁТЕСЛИ( $A$2:$A$30 ;»>12″)
Подсчитать числа, которые больше нуля: =СЧЁТЕСЛИ( $A$2:$A$30 ;»>0″) Подсчитать количество непустых ячеек: =СЧЁТЕСЛИ( $A$2:$A$30 ;»<>«)
Как видно из второго рисунка — там наименования не повторяются, хотя в таблице они все записаны вперемешку. Я не буду заострять на этом внимание — я уже описывал это в статье Как получить список уникальных(не повторяющихся) значений? и при необходимости можно воспользоваться любым описанным в ней методом.
Но. Бывают случаи, когда список расположен вовсе не в таблице, а в одной ячейке( $D$1 ): Дыня Киви Груша Яблоко Дыня Груша Груша Арбуз Яблоко Банан Яблоко Яблоко Банан Яблоко Яблоко Дыня Дыня Киви Банан Дыня Арбуз Дыня Киви Яблоко Дыня Груша Яблоко Киви Арбуз Здесь СЧЁТЕСЛИ точно не поможет. Но в Excel полно других функций и все можно сделать так же достаточно просто: =(ДЛСТР( $D$1 )-ДЛСТР(ПОДСТАВИТЬ( $D$1 ; D3 ;»»)))/ДЛСТР( D3 ) ДЛСТР — подсчитывает количество символов в указанной ячейке/строке( $D$1 , D3 ) ПОДСТАВИТЬ (текст; старый_текст; новый_текст) — заменяет в указанном тексте заданный символ на любое другое заданное значение. По умолчанию заменяет все повторы указанного символа. Именно это и положено в основу алгоритма. На примере значения Банан( D3 ) пошаговый разбор формулы:
при помощи функции ДЛСТР получаем количество символов в строке с исходным текстом( $D$1 ) =(170-ДЛСТР(ПОДСТАВИТЬ( $D$1 ; D3 ;»»)))/ДЛСТР( D3 ) ;
при помощи функции ПОДСТАВИТЬ заменяем в строке с исходным текстом( $D$1 ) все значения Банан( D3 ) на пусто и при помощи ДЛСТР получаем количество символов строки после этой замены =(170-155)/ДЛСТР( D3 ) ;
вычитаем из общего количества символов количество символов в строке после замены и делим результат на количество символов в критерии =(170-155)/5 .
Получаем число 3. Что нам и требовалось.
И простая функция пользователя, которая так же подсчитывает повторения внутри ячейки:
Function GetRepeat(sTxt As String, sCntWord As String) GetRepeat = (Len(sTxt) — Len(Replace(sTxt, sCntWord, «»))) / Len(sCntWord) End Function
Чтобы правильно использовать приведенный код, необходимо сначала ознакомиться со статьей Что такое функция пользователя(UDF)?. Вкратце: скопировать текст кода выше, перейти в редактор VBA( Alt + F11 ) -создать стандартный модуль(Insert —Module) и в него вставить скопированный текст. После чего функцию можно будет вызвать из Диспетчера функций( Ctrl + F3 ), отыскав её в категории Определенные пользователем (User Defined Functions) . Синтаксис функции: =GetRepeat( $D$1 ; D3 ) sTxt — текст, в котором подсчитываем кол-во вхождения. sCntWord — текст для подсчета. Может быть символом или словом.
Нужно посчитать количество повторений по столбцу рейс только в одной строке. Рейс. Объем. Колич повтор 1аб. 2 2 1ав. 3. 1 1 аб. 0.3. 2 (2нужно посчитать как 0) 2аг. 9. 2 2аг. 3. 2 (2нужно посчитать как 0) 2ав. 0.4. 1
Убрать дубликаты не могу, т.к удаляет всю строку, а значения в поле объем нужны для дальнейшего расчета. Упорядочить значения в столбце рейс тоже нельзя, т.к во всей исходной таблице есть объединенные ячейки, которые нельзя разбить.
Попробуйте задать вопрос в форуме , приложив пример файла с данными. По одному описанию у меня не получается понять задачу.