Как найти отрицательные значения в эксель

Обновлено: 03.07.2024

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

Предложенное решение этой задачи имеет один существенный недостаток. Дело в том, что функция МАКС возвращает первое максимальное значение из диапазона и на этом весь расчет прекращается. Это означает, что если в списке будет два или больше сотрудников с одинаковым возрастом, то в результатах мы увидим лишь первого по списку.

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

Итак, первым делом мы по-прежнему должны определить максимальный возраст. Для этого вполне подойдет функция МАКС , которую мы уже использовали ранее.

Ну а далее нам нужно сравнивать возраст каждого сотрудника с максимальным и в случае совпадения выводить имя сотрудника в столбце F ниже.

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

Дело в том, что все стандартные функции Экселя, которые сразу приходят на ум, выдадут лишь первое значение из диапазона, удовлетворяющее условию. Поэтому нам придется воспользоваться формулой массива .

Формула массива является частью стандартного функционала Экселя и многие даже не догадываются об ее существовании.

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

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

Итак, давайте решим задачу.

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

Первый ее аргумент - массив значений. Выбираем все ячейки с именами сотрудников.

На листе есть список чисел, которые имеют как положительные, так и отрицательные числа, если вы хотите найти первое или последнее положительное или отрицательное число в этом столбце, как вы могли бы это сделать?

Найдите первое положительное / отрицательное число с помощью формулы массива

Чтобы получить первое положительное или отрицательное число в списке данных, вам может помочь следующая формула, сделайте следующее:

1. В пустой ячейке, помимо ваших данных, введите следующую формулу массива: =INDEX(A2:A18,MATCH(TRUE,A2:A18>0,0)) (A2: A18 это список данных, который вы хотите использовать), см. снимок экрана:

док-найти-первое-положительное-число-1

2, Затем нажмите Shift + Ctrl + Enter вместе, чтобы вернуть первое положительное число в списке, см. снимок экрана:

док-найти-первое-положительное-число-2

Внимание: Чтобы получить первое отрицательное число в списке, вам просто понадобится эта формула: =INDEX(A2:A18,MATCH(TRUE,A2:A18<0,0)) , и не забудьте нажать Shift + Ctrl + Enter ключи одновременно.

Найдите последнее положительное / отрицательное число с помощью формулы массива

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

1. Введите следующую формулу в пустую ячейку рядом с вашими данными, = ПРОСМОТР (9.99999999999999E + 307; ЕСЛИ ($ A $ 2: $ A $ 18> 0, $ A $ 2: $ A $ 18)) ( A2: A18 это список данных, который вы хотите использовать), см. снимок экрана:

док-найти-первое-положительное-число-3

2, Затем нажмите Shift + Ctrl + Enter ключи одновременно, чтобы вернуть последнее положительное число в списке, см. снимок экрана:

док-найти-первое-положительное-число-4

Внимание: Чтобы получить последнее отрицательное число в списке, вам просто нужна эта формула: = ПРОСМОТР (9.99999999999999E + 307; ЕСЛИ ($ A $ 2: $ A $ 18 <0, $ A $ 2: $ A $ 18)) , и не забудьте нажать Shift + Ctrl + Enter ключи вместе.

Часто случается, что в одном диапазоне ячеек находятся вместе положительные и отрицательные числа. Необходимо определить экстремальные значения, но с определенными условиями. Следует получить наименьшее значение для положительных чисел и отдельно для отрицательных. Для решения данной задачи не достаточно просто использовать функции =МИН(), =МАКС() или =НАИМЕНЬШИЙ(), =НАИБОЛЬШИЙ(). Иначе при обращении функций к диапазону с перемешанными положительными и отрицательными числами, будет возвращено только отрицательное наименьшее значение. Поэтому следует использовать специальную формулу с функциями.

Наименьшее положительное число

Допустим у нас есть статистика доходов и расходов сети магазинов за месяц. А нам нужно узнать какие из торговых точек наименее затратные по расходам и наименее прибыльны по доходам. Для презентации решения будем использовать пример таблицы с доходами и расходами магазинов как показано на рисунке:

Доходы и расходы.

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

  1. В ячейке D2 введем следующую формулу:
  2. После ввода формулы для подтверждения необходимо нажать комбинацию горячих клавиш: CTRL+SHIFT+Enter, так как она должна выполняться в массиве. Если все сделано правильно тогда в строке формул будут видны фигурные скобки.

Разбор принципа действия формулы для поиска наименьшего положительного числа:

Логическая функция =ЕСЛИ(), которая выполняется в массиве формул, проверяет каждую ячейку диапазона C2:C13 какая из них содержит число меньше чем 0 или равно нулю (<=0). Таким образом создается условная таблица в памяти с логическими значениями:

  • ЛОЖЬ – для положительных чисел (в данном случаи и для нуля);
  • ИСТИНА – для отрицательных чисел.

После чего в условной таблице функция ЕСЛИ заменяет все значения ИСТИНА на пустые (””). А вместо значения ЛОЖЬ подставляются те числа положительные, которые и были раньше в диапазоне C2:C13. И завершает вычисления формулы функция =МИН(), которая из условной таблицы (уже отфильтрованной от отрицательных значений и нулей) возвращает нам наименьшее положительное число.

Наибольшее отрицательное число в диапазоне ячеек

Чтобы найти наименьшие расходы среди отрицательных значений укажите наибольшее. Для этого следует выполнить следующие действия:

  1. В ячейке E2 введите формулу: =0;””;C2:C13))' >
  2. Так же, как и предыдущей формуле после ввода необходимо нажать комбинацию клавиш: CTRL+SHIFT+Enter, так как она должна выполняться в массиве. Если все сделано правильно в строке формул появятся фигурные скобки.

В результате мы быстро и легко переделили самый слабый магазин по доходам – это №4. А наименее затратная торговая точка по расходам – это магазин №2.

В процессе работы с большим объемом числовых данных в таблицах очень удобно различать цветами положительные и отрицательные значения. Таким образом таблица приобретает более чит Принцип выделения цветом отрицательных и положительных числовых значений:

Значение каждой ячейки проверено в соответствии с первым критерием, а потом с другим. Оба условия можно выразить формулой:

Введите данную формулу в ячейку D2, а потом скопируйте ее в остальные ячейки диапазона D2:D8.

Test.

Формула проверила соответствие оформления ячеек с критериями и наглядно отобразила принцип действия автоматического выделения цветом данных.

Как выделить строку с отрицательным значением в Excel

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

Рассмотрим, как выделить строку в Excel цветом автоматически:

  1. Удалим ранее созданное условное форматирование: «ГЛАВНАЯ»-«Условное форматирование»-«Удалить правила»-«Удалить правила со всего листа».
  2. Выделите диапазон ячеек A2:D8 и выберите инструмент: «ГЛАВНАЯ»-«Условное форматирование»-«Создать правило».
  3. В разделе данного окна «Выберите тип правила:» выберите опцию «Использовать формулу для определения форматированных ячеек».
  4. В поле ввода введите формулу: =$C2<0 (обратите внимание на смешанную ссылку).
  5. Щелкните по кнопке «Формат» и в паявшемся окне перейдите на вкладку «Шрифт», в разделе «Цвет:» выберите красный. После на всех открытых окнах нажмите «ОК».

Результат действия формулы с условным форматированием, которая сделала таблицу еще более читабельной.

Результат.

Примечание. Таким же самым образом можно присвоить диапазону A2:D8 новое правило для выделения строк на против ячеек с положительным значением другим цветом. Только нужно указать другую формулу: =$C2>0 и задать другой желаемый формат.

Полезный совет! При редактировании формул в поле окна «Создания правила форматирования» не используйте стрелки на клавиатуре для перемещения клавиатурного курсора. Это приведет к перемещению по ячейкам курсора Excel для автоматического заполнения ссылками в аргументах формулы. Если же Вы хотите использовать стрелки клавиатуры для редактирования, то сначала нажмите клавишу F2 (она работает как переключатель между режимами редактирования и автозаполнения аргументов).

Разбор принципа действия автоматического выделения строк красным цветом с отрицательным значением:

Если нужно выделить цветом целую строку таблицы в, которой находится ячейка (определенного столбца) с отрицательным числовым значением следует использовать соответственные смешанные адреса ссылок в аргументах формулы. Первое действие, которое мы выполнили при решении данной задачи – это выделение всего диапазона A2:D8. Это значит, что каждая ячейка данного диапазона будет проверена на соответствие с условиями правил форматирования относительно определенного столбца, на который формула ссылается абсолютной ссылкой =$C. Это значит, что формула будет выполнятся, учитывая значения только в определенном столбце $C. Перед номером строки отсутствует символ $ это значит, что формат распространяется и на другие ячейки вдоль конкретной строки.

Читайте также: