Как посчитать два условия в Excel: 5 рабочих способов с примерами

Почему стандартный СЧЁТЕСЛИ не подходит для двух условий?

Вы когда-нибудь пытались посчитать в Excel количество строк, где одновременно выполняются два условия — например, продажи конкретного товара в определённом регионе? Если да, то наверняка столкнулись с ограничением функции СЧЁТЕСЛИ: она умеет работать только с одним критерием. Даже опытные пользователи иногда тратят часы на обходные манёвры с промежуточными столбцами или вложенными формулами, не подозревая о существовании более элегантных решений.

В этой статье мы разберём 5 способов подсчёта по двум условиям — от базовых функций до продвинутых техник с массивами. Вы узнаете, когда лучше использовать СЧЁТЕСЛИМН, а когда — комбинацию СУММПРОИЗВ с логическими выражениями. Особое внимание уделим распространённой ошибке с диапазонами в СЧЁТЕСЛИМН, из-за которой 80% пользователей получают неверный результат. Готовы оптимизировать свои таблицы?

Способ 1: Функция СЧЁТЕСЛИМН — базовый инструмент

Функция СЧЁТЕСЛИМН (англ. COUNTIFS) создана специально для подсчёта ячеек с несколькими условиями. Её синтаксис прост:

=СЧЁТЕСЛИМН(диапазон1; условие1; [диапазон2; условие2]; ...)

Ключевое правило: диапазоны должны быть одинакового размера. Если первый диапазон охватывает 100 строк, а второй — только 50, формула вернёт ошибку. Рассмотрим пример:

ТоварРегионПродажи
НоутбукМосква15
СмартфонСПб22
НоутбукМосква8
ПланшетКазань5

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

=СЧЁТЕСЛИМН(A2:A5; "Ноутбук"; B2:B5; "Москва")
⚠️ Внимание: Если в условии используете текст с пробелами или специальными символами (например, "Смартфон Pro+"), обязательно заключайте его в двойные кавычки: "=Смартфон Pro+". Иначе Excel воспримет это как ошибку синтаксиса.
  • ✅ Подходит для текстовых, числовых и логических условий
  • ✅ Можно добавлять до 127 пар "диапазон-условие"
  • ❌ Не работает с регулярными выражениями (для этого нужен СУММПРОИЗВ)
  • ❌ Требует строгого соответствия размеров диапазонов

Диапазоны имеют одинаковое количество строк и столбцов

Текстовые условия заключены в кавычки

Учтёны регистр букв (если важно)

Нет скрытых символов в данных (пробелы, переносы)

-->

Способ 2: СУММЕСЛИМН — когда нужно не только считать, но и суммировать

Если вам требуется не просто подсчитать строки с двумя условиями, а просуммировать значения в них (например, общие продажи ноутбуков в Москве), используйте СУММЕСЛИМН (англ. SUMIFS). Её синтаксис аналогичен СЧЁТЕСЛИМН, но добавляется диапазон для суммирования:

=СУММЕСЛИМН(диапазон_суммирования; диапазон1; условие1; [диапазон2; условие2]; ...)

Для нашего примера с таблицей формула будет:

=СУММЕСЛИМН(C2:C5; A2:A5; "Ноутбук"; B2:B5; "Москва")

Эта формула вернёт 23 — сумму продаж ноутбуков в Москве (15 + 8). Обратите внимание, что диапазон суммирования указывается первым, а не последним, как интуитивно может показаться.

=СУММЕСЛИМН(...)/СЧЁТЕСЛИМН(...)

-->

Способ 3: Комбинация СУММПРОИЗВ + логические выражения

Когда условия сложнее простого равенства (например, "продажи > 10 И регион = Москва"), на помощь приходит СУММПРОИЗВ. Эта функция умножает массивы и возвращает сумму произведений, но её можно адаптировать для подсчёта:

=СУММПРОИЗВ(--(A2:A5="Ноутбук"); --(B2:B5="Москва"))

Разберём, как это работает:

  1. A2:A5="Ноутбук" возвращает массив {ИСТИНА; ЛОЖЬ; ИСТИНА; ЛОЖЬ}
  2. Двойной унарный минус (--) преобразует ИСТИНА в 1, а ЛОЖЬ в 0: {1; 0; 1; 0}
  3. СУММПРОИЗВ умножает массивы поэлементно и суммирует результаты: 1*1 + 0*0 + 1*1 + 0*0 = 2

Преимущество этого метода — гибкость. Вы можете использовать:

  • 🔹 Сравнения: ">10", "<=50"
  • 🔹 Логические операторы: И(), ИЛИ() внутри массива
  • 🔹 Подстановочные знаки: "Ноутбук*", "*Pro"
⚠️ Внимание: В новых версиях Excel (365, 2021) СУММПРОИЗВ с массивами может требовать нажатия Ctrl+Shift+Enter для корректной работы. В Excel Online это не нужно.
Почему двойной минус (--)?

Одиночный минус (-) преобразует ИСТИНА/ЛОЖЬ в -1/0, а двойной — в 1/0. Это необходимо, чтобы СУММПРОИЗВ корректно суммировал результаты.

-->

Способ 4

Фильтр + функция СТРОКА (для динамических диапазонов)

Если ваши данные часто обновляются, и вы не хотите вручную корректировать диапазоны в формулах, используйте динамические массивы с функцией ФИЛЬТР (доступна в Excel 365 и 2021):

=СТРОКА(ФИЛЬТР(A2:B5; (A2:A5="Ноутбук")*(B2:B5="Москва"); ""))

Как это работает:

  1. ФИЛЬТР возвращает только строки, соответствующие обоим условиям
  2. СТРОКА преобразует отфильтрованный диапазон в массив номеров строк
  3. Количество элементов в результирующем массиве = количество совпадений

Чтобы получить именно количество строк, оберните формулу в СЧЁТ:

=СЧЁТ(СТРОКА(ФИЛЬТР(A2:B5; (A2:A5="Ноутбук")*(B2:B5="Москва"); "")))

Этот метод особенно полезен для интерактивных дашбордов, где данные меняются в реальном времени. Например, вы можете создать выпадающий список с товарами и регионами, а формула будет автоматически пересчитывать результаты.

СЧЁТЕСЛИМН|СУММЕСЛИМН|СУММПРОИЗВ|Фильтр+СТРОКА|Другой

Способ 5: Power Query для сложных условий

Когда условия становятся слишком комплексными (например, "продажи в Москве или СПб, но не планшеты, и только по будням"), обычные формулы теряют читаемость. В таких случаях на помощь приходит Power Query — инструмент для преобразования данных, встроенный в Excel 2016+.

Алгоритм действий:

  1. Выделите исходную таблицу и нажмите Данные → Из таблицы/диапазона
  2. В редакторе Power Query добавьте фильтры:
    • 🔹 Фильтр по столбцу "Товар": исключите "Планшет"
    • 🔹 Фильтр по столбцу "Регион": оставьте "Москва" и "СПб"
    • 🔹 Добавьте пользовательский столбец с формулой =Date.DayOfWeek([Дата]) < 6 (будни)
  • Нажмите Закрыть и загрузить — Excel создаст новую таблицу с отфильтрованными данными
  • Используйте СЧЁТ или СЧЁТЗ для подсчёта строк в результирующей таблице
  • Преимущества Power Query:

    • 📊 Визуальный интерфейс для создания фильтров (не нужно запоминать синтаксис)
    • 🔄 Автоматическое обновление при изменении исходных данных
    • 📎 Возможность сохранять шаги обработки для повторного использования
    ⚠️ Внимание: Power Query создаёт отдельную копию данных, что может увеличить размер файла. Для больших таблиц (100 000+ строк) используйте этот метод осторожно или оптимизируйте запрос через Таблицу промежуточных результатов.

    Типичные ошибки и как их избежать

    Даже опытные пользователи Excel допускают ошибки при работе с двумя условиями. Вот TOP-5 ловушек и способы их обхода:

    ОшибкаПричинаРешение
    #ЗНАЧ! в СЧЁТЕСЛИМН Диапазоны разного размера Проверьте количество строк в диапазон1 и диапазон2 с помощью СТРОКА()
    Неверный результат в СУММПРОИЗВ Забыли двойной минус (--) Всегда используйте --(условие) для преобразования ИСТИНА/ЛОЖЬ в 1/0
    Формула не обновляется Диапазоны зафиксированы абсолютными ссылками ($A$1:$A$10) Используйте относительные ссылки (A1:A10) или именованные диапазоны
    Ошибка #ИМЯ? Опечатка в названии функции (например, СЧЁТЕСЛИМ вместо СЧЁТЕСЛИМН) Проверьте синтаксис или используйте автозаполнение (вводите =СЧЁТ и выбирайте из списка)
    Не учитываются пустые ячейки СЧЁТЕСЛИМН игнорирует пустые значения по умолчанию Добавьте условие "" или используйте СЧЁТЗ для подсчёта непустых ячеек

    Ещё одна распространённая проблема — несоответствие форматов данных. Например, если в одном столбце даты хранятся как текст ("01.01.2026"), а в другом — как даты (45292), сравнение не сработает. Используйте ДАТАЗНАЧ() или ТЕКСТ() для приведения к единому формату:

    =СЧЁТЕСЛИМН(A2:A5; ДАТАЗНАЧ("01.01.2026"); B2:B5; ">100")

    Практические примеры для разных сфер

    Давайте рассмотрим, как применять эти методы в реальных задачах. Возьмём три сценария: анализ продаж, учёт посещаемости и финансовый контроль.

    1. Анализ продаж (торговля)

    Задача: Посчитать количество заказов на сумму > 5000 руб., оплаченных наличными в январе 2026.

    =СЧЁТЕСЛИМН(D2:D100; ">5000"; E2:E100; "Наличные"; B2:B100; ">="&ДАТА(2026;1;1); B2:B100; "<="&ДАТА(2026;1;31))

    2. Учёт посещаемости (образование)

    Задача: Найти студентов, пропустивших более 3 занятий по математике, но посещавших все лекции по физике.

    =СУММПРОИЗВ(--(B2:B100="Математика"); --(C2:C100>3); --(СЧЁТЕСЛИМН($A$2:$A$100; A2:A100; $B$2:$B$100; "Физика"; $C$2:$C$100; 0)=0))

    3. Финансовый контроль (бухгалтерия)

    Задача: Суммировать расходы по статье "Канцтовары", утверждённые директором (в столбце "Статус" стоит "Утверждено").

    =СУММЕСЛИМН(D2:D100; A2:A100; "Канцтовары"; C2:C100; "Утверждено")

    Для визуализации результатов комбинируйте эти формулы с условным форматированием или сводными таблицами. Например, можно выделить красным ячейки, где количество пропусков превышает допустимый лимит.

    FAQ: Ответы на частые вопросы

    Можно ли использовать СЧЁТЕСЛИМН для подсчёта по трём и более условиям?

    Да, СЧЁТЕСЛИМН поддерживает до 127 пар "диапазон-условие". Синтаксис остаётся тем же: просто добавьте дополнительные аргументы. Пример для трёх условий:

    =СЧЁТЕСЛИМН(A2:A100; "Ноутбук"; B2:B100; "Москва"; C2:C100; ">10")

    Главное правило: все диапазоны должны быть одного размера.

    Как посчитать уникальные значения по двум условиям?

    Для подсчёта уникальных значений (например, уникальных клиентов, сделавших заказ в Москве на сумму > 1000 руб.) используйте комбинацию СУММПРОИЗВ и ЧАСТОТА:

    =СУММ(--(ЧАСТОТА(ЕСЛИ((A2:A100="Москва")*(B2:B100>1000); СТРОКА(A2:A100)-1); СТРОКА(A2:A100)-1)>0))

    Эта формула требует подтверждения Ctrl+Shift+Enter в старых версиях Excel.

    Почему СУММЕСЛИМН возвращает 0, хотя есть совпадения?

    Наиболее вероятные причины:

    1. В диапазоне суммирования содержатся текстовые значения вместо чисел (например, "15 руб" вместо 15). Используйте ЗНАЧЕН() для преобразования.
    2. Условия чувствительны к регистру (например, "Москва" ≠ "москва"). Приведите данные к единому регистру с помощью ПРОПИСН() или СТРОЧН().
    3. Диапазоны суммирования и условий не пересекаются по строкам. Проверьте выравнивание данных.
    Как посчитать процент строк, удовлетворяющих двум условиям?

    Используйте комбинацию СЧЁТЕСЛИМН и СЧЁТ:

    =СЧЁТЕСЛИМН(A2:A100; "Да"; B2:B100; ">50") / СЧЁТ(A2:A100)

    Чтобы отобразить результат в процентах, примените процентный формат к ячейке (Ctrl+Shift+%).

    Можно ли использовать подстановочные знаки (* и ?) в условиях?

    Да, но только в функциях СЧЁТЕСЛИМН и СУММЕСЛИМН. Примеры:

    • "Ноутбук*" — найдёт "Ноутбук", "Ноутбук Pro", "Ноутбук 15"
    • "???он" — найдёт "Смартфон", "Телефон" (ровно 3 символа перед "он")
    • "2026" — найдёт любые значения, содержащие "2026"

    В СУММПРОИЗВ подстановочные знаки не работают — используйте ПОИСК() или НАЙТИ():

    =СУММПРОИЗВ(--(НАЙТИ("Про"; A2:A100)>0); --(B2:B100="Москва"))