Функции ИНДЕКС и ПОИСКПОЗ в Excel – лучшая альтернатива для ВПР – ОфисГуру

Проблема не в том, что у нас нехватка данных, проблема в том, что у нас их слишком много; что просто уже сложно найти суть в этих данных. Вам нужен способ переорганизации и очистки ваших данных,…

Задача

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

Для поиска значения на пересечении строки и столбца можно использовать разные подходы (см. файл примера, лист Пример1 ).

Таблицы вокруг нас

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

Посмотрите на этот пример.

1 tablicy

Можно заметить, что у этого черно-белого примера четко видна структура. Простые таблицы состоят из нескольких столбцов и строк с одноуровневыми заголовками.

Пример цветного оформления:

2 tablicy
Источник

Это пример без видимых границ столбцов или строк. Но структура все равно видна.

3 tablicy

Несмотря на различие, цветные или черно-белые варианты, с границами и без, они все обладают подобной структурой. Это перпендикулярное пересечение столбцов и строк с образование ячеек – минимального структурного элемента, в котором и находятся данные.

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

Способ 1. Использовать функцию ТРАНСП.

В случае, когда вам нужно быстро изменить ориентацию вашей таблицы, можно использовать функцию ТРАНСП (TRANSPOSE в англоязычной версии).

Назначение функции ТРАНСП в Excel – превратить строки в столбцы, т. е. поменять ориентацию с горизонтальной на вертикальную или наоборот.

Функция ТРАНСП в Excel – синтаксис

Функция транспонировать принимает только один аргумент:

= ТРАНСП(массив)

Где массив – это диапазон для транспонирования. Данные преобразуются следующим образом: первая строка исходного диапазона становится первым столбцом нового, вторая строка становится вторым столбцом и так далее.

Синтаксис ТРАНСП не оставляет места для ошибок при создании формулы. Более сложная задача –  правильно записать её на рабочий лист. Если у вас нет большого опыта работы с формулами Excel в целом и формулами массивов в частности, внимательно следуйте приведенным ниже инструкциям.

1. Подсчитайте количество столбцов и строк в исходной таблице.

Эти числа понадобятся вам на следующем шаге.

В этом примере мы собираемся транспонировать небольшую табличку, которая показывает объем экспорта свежих фруктов по регионам:

2. Выберите такое же количество ячеек, но измените их ориентацию.

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

В нашем случае мы выбираем диапазон из 5 столбцов и 4 строк:

3. Введите формулу ТРАНСП.

Выделив этот пустой диапазон, используйте функцию транспонирования:

=ТРАНСП(A1:D5)

Вот подробные шаги:

Сначала вы вводите знак равенства, имя функции и открывающую скобку: = ТРАНСП(

Затем выберите исходный диапазон с помощью мыши или введите его вручную:

Наконец, введите закрывающую скобку, но не нажимайте клавишу Enter! На этом этапе ваша формула должна выглядеть примерно так:

4. Запишите формулу.

Нажмите Ctrl + Shift + Enter, чтобы правильно закончить формулу массива. Зачем это? Потому что формула должна применяться ко всем данным. И это именно то, для чего предназначены формулы массива.

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

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

Преимущества функции ТРАНСП:

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

Слабые стороны функции ТРАНСП:

  • Исходное форматирование не сохраняется в преобразованной таблице, как вы видите на скриншоте выше.
  • Если в исходной таблице есть пустые клетки, вместо них ячейки новой таблицы будут содержать ноль. Чтобы исправить это, используйте ТРАНСП в комбинации с функцией ЕСЛИ, как описано в этом примере ниже: Как транспонировать без нулей.
  • Вы не можете редактировать какие-либо данные в преобразованной таблице, потому что она полностью завязана на исходные данные. Если вы попытаетесь изменить какое-либо значение, то получите ошибку «Вы не можете изменить часть массива».

Итак, какой бы хорошей и простой в использовании не была бы функция ТРАНСП, ей определенно не хватает гибкости. Поэтому она может быть не самым оптимальным вариантом во многих ситуациях.

Как транспонировать таблицу без замены нулей на пробелы.

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

То есть, если при транспонировании строки в столбец программа обнаруживает пустую ячейку, то вместо нее сразу же вставляется ноль. Это особенность Экселя: стоит с пустой ячейкой произвести какую-то математическую операцию, и там тут же появляется ноль. А транспонирование в Excel – это математическая операция с матрицей значений.

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

Если вы хотите оставить в новой таблице по-прежнему пустые ячейки, а не нули, то вложите функцию ЕСЛИ в формулу ТРАНСП, чтобы предварительно проверить, является ли ячейка пустой. Если она пуста, функция ЕСЛИ вернет пустую строку (“”), в противном случае предоставит значение для транспонирования:

=ТРАНСП(ЕСЛИ(A1:D5=””;””;A1:D5))

Введите формулу, как описано выше (не забудьте нажать Ctrl + Shift + Enter, чтобы правильно завершить формулу массива), и вы получите результат, подобный этому:

Как видите, мы транспонируем не все ячейки, а только непустые.

Советы по использованию ТРАНСП

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

1. Как редактировать формулу?

Как функция массива, ТРАНСП не позволяет изменять часть возвращаемого массива. Чтобы отредактировать формулу транспонирования, выберите весь диапазон, к которому относится формула, внесите необходимые изменения и нажмите Ctrl + Shift + Enter, чтобы сохранить обновленную формулу.

2. Как удалить формулу?

Чтобы удалить формулу транспонирования с листа, выберите весь диапазон, на который имеется ссылка в формуле, и нажмите клавишу Del.

3. Как заменить формулу на значения?

Когда вы переворачиваете таблицу с помощью функции ТРАНСП, исходная и новая таблицы связываются. Это означает, что всякий раз, когда вы изменяете какое-либо значение в исходной таблице, соответствующее значение в новой изменяется автоматически.

Если вы хотите разорвать связь между ними, замените формулы вычисленными значениями. Для этого выберите все ячейки преобразованной таблицы, затем нажмите Ctrl + C, чтобы скопировать их в буфер обмена. Кликните правой кнопкой мыши и выберите в контекстном меню «Специальная вставка» > « Значения». Или используйте для вставки значений вместо формул комбинацию клавиш Ctrl+Alt+V.

Из строки в столбец в Excel

Для выполнения этого действия необходимо выделить и скопировать нужную область (CTRL+C).

Копирование строки с значениями в Excel

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

Преобразование строки в столбец через транспонирование в Excel

Все готово.

Результат преобразования из строки в столбец в Excel

Зачем преобразовывать столбцы в строки?

Прежде чем мы начнём, вам может быть интересно, почему полезно использовать данные, которые расположены в столбцах и преобразовать их в строки.

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

В приведенном ниже примере вы можете увидеть, как выглядят данные в Excel, если преобразовать их из столбцов в строки. С левой стороны, находится набор записей о клиентах и разными типами проектов в столбцах. С правой стороны я отменил свёртывание данных и конвертировал их в формат строки.

Converting columns to Rows in Microsoft ExcelConverting columns to Rows in Microsoft ExcelConverting columns to Rows in Microsoft ExcelПреобразование столбцов в строки в Microsoft Excel.

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

Вкратце: преобразование данных из столбцов в строки облегчает работу. Power Query делает это запросто, в пару кликов. Давайте узнаем, как:

Как вставить пустую строку на лист Excel

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

  1. Выделяем строчку на листе, над которой необходимо вставить дополнительную строчку. Затем переходим во вкладку «Главная», в блоке «Ячейки» выбираем кнопку «Вставить», а в выпадающем списке «Вставить строки на лист.

№ 20.png

  1. Вы заметите, что одна строчка смещается вниз под тем же номером. Такую операцию можно проделать с уже имеющимися таблицами. Можно сделать вставку другим способом: снова зайдите в блок «Ячейки», затем кликните на кнопку «Вставить ячейку». Высветится контекстное меню, в котором необходимо переустановить флажок на «Строку».

№ 21.png

Полезно знать!

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

Электронная таблица в информатике: что это такое

ЭТ – это и приложение для работы числовой информацией в виде двухмерных массивов – электронных таблиц, и сам массив данных – способ структурирования информации по строкам и столбикам. В первом случае это – программа, например, Excel, во втором – содержимое документа, который она способна создать и обработать.

Ещё программу для обработки двухмерных массивов называют табличным процессором.

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

Электронная таблица в информатике: что это такое

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

Кратко о появлении и развитии
Название ЭТ получили от слова «spreadsheet» – размеченного линиями листа, используемого в бухгалтерии и сфере финансов на протяжении сотен лет. В начале 1960-х годов Р. Миттсен, профессор из Беркли, описал программу для работы с бюджетом, рассчитанную на работу с двухмерными матрицами. Она умела работать с формулами для каждой ячейки.

Концепцию дополнили Ландау и Пардо в конце 1960-х благодаря разработке LANPAR, запатентованной в 1983 году. Программа умела работать с ячейками, тогда их называли боксами, путём адресного обращения к ним по номеру столбика и строчки.

Это были прообразы современных ЭТ. Первой электронной таблицей считается VisiCalc – разработка студента Гарвардской школы бизнеса Д. Бриклина.

Это были прообразы современных ЭТ. Первой электронной таблицей считается VisiCalc – разработка студента Гарвардской школы бизнеса Д. Бриклина.

Поиск с помощью функции ИНДЕКС()

Запишем длинную, но простую для понимания формулу =ИНДЕКС($B$13:$G$21;ПОИСКПОЗ(D10;$A$13:$A$21;0);ПОИСКПОЗ(E9;$B$12:$G$12;0))

Две функции ПОИСКПОЗ() определяют номер строки и столбца для функции ИНДЕКС() . Для однозначного поиска номера строки (столбца), в этих диапазонах не должно быть повторов.

Преобразование столбца в строку через запятую в Excel

Используем формулу «лесенка».
Скачать готовый файл можно здесь: 4memo-ru-stolbik-zapyataya.xls
Запятую в самой первой ячейке можно заменить, на что-то другое, если нужно.
Формулу во втором столбце растягиваем вниз, насколько потребуется.
Если полученный список нужно вставить в другой лист эксель, то не забываем избавиться от формул, вставив предварительно данные в блокнот.

Поиск с помощью функции СУММПРОИЗВ()

Другой вариант поиска – использование функции СУММПРОИЗВ() =СУММПРОИЗВ((B12:G12=J9)*(A13:A21=I10)*(B13:G21))

Поиск методом пересечения

В EXCEL существует малоизвестный метод Пересечений , основанный на использовании именованных диапазонов . Для создания пересечения сделайте следующее:

  • выделите диапазон A7: G 16 (таблицу продаж вместе с заголовками);
  • нажмите кнопку « Создать из выделенного фрагмента » ( );
  • убедитесь, что стоят галочки « В строке выше » и « В столбце слева »;
  • нажмите ОК.

Проверить, какие имена были созданы, можно через Диспетчер Имен ( ).

EXCEL создал 15 именованных диапазонов. В качестве имен использованы 6 названий месяцев и 9 марок автомобилей. Теперь произведем, собственно, поиск.

  • введите в ячейки А10 и B9 два критерия: Янв и Saab (определим продажи Saab в январе)
  • введите формулу =ДВССЫЛ(A10) ДВССЫЛ(B9) (между функциями ДВССЫЛ() – пробел).
  • Нажмите ENTER .

При вычислении, вместо формул с ДВССЫЛ() будут подставлены, определенные ранее имена: Янв и Saab , совпадающие с критериями. Наличие пробела означает, что будет использован метод Пересечений – будет выведено значение на пересечении соответствующих именам строке и столбцу.

Разберем подробнее. В Строке формул выделите ДВССЫЛ(A10) и нажмите клавишу F9 . Получим значения соответствующего именованного диапазона Saab { 3600 ;1520;5480;4588;5336;2588}. Затем выделите ДВССЫЛ(B9) . Получим другой массив {4064:1992:812:3185:4617: 3600 :5594:4218:3637}. Метод пересечений вернет значение на пересечении строки и столбца, т.е. 3600 .

Таблицы для решения логических задач

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

Пример логической задачи

19 tablicy

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

20 tablicy

Согласно данным по первому туру Саша не может быть 6-классником, Катя – 7-классницей, а Наташа 9-классницей. Ставим на пересечении имен и классов . Исходя из того, что они играли парами, Саша также не ходит в 7, 9 классы, Катя – 6, 9, а Наташа – 6 и 7. Добавим −.

Переходим к описанию второго тура: Петя не может быть в 7 классе. Ставим в этой ячейке напротив Пети и «7» .

В третьем и четвертом турах из-за болезни 9-классника Петя и Руслан не играли. Ставим в этой ячейке .

Данные по 4-ому туру позволяют отметить, что Катя не 11-классница. Ставим на пересечении Катя/«11» .

Так как победили Саша и Катя, и они не 10-классники. Ставим  в столбце со значением 10 напротив имен Кати и Саши.

А теперь, методом исключения, определим, кто в каком классе учится, ведь на соревнованиях было по 1 человеку от каждого класса. Сначала поставим + в тех строках, где пустыми остались по 1 ячейке, далее в этом столбце, если представитель от этого класса уже найден.

21 tablicy

Получилось, что Катя 8-классница, а Андрей из 9-классник, Саша – из 11 класса, Наташа из 10, Петя – из 6, а Руслан из 7.

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

Рейтинг
( 1 оценка, среднее 5 из 5 )
Загрузка ...