Динамические массивы в Excel
Что такое динамические массивы
В сентябре 2018 года Microsoft выпустила обновление, которое добавляет в Microsoft Excel совершенно новый инструменты: динамические массивы (Dynamic Arrays) и 7 новых функций для работы с ними. Эти вещи, без преувеличения, совершенно кардинальным образом меняет всю привычную технику работы с формулами и функциями и касаются, буквально, каждого пользователя.
Рассмотрим простой пример, чтобы объяснить суть.
Предположим, что у нас есть простая табличка с данными по городам-месяцам. Что будет если мы выделим любую пустую ячейку справа на листе и введем в нее формулу-ссылку не на одну ячейку, а сразу на диапазон?
Во всех прошлых версиях Excel после нажатия на Enter мы бы получили содержимое только одной первой ячейки B2. А как иначе?
Ну, или можно было бы завернуть этот диапазон в какую-нибудь аггрегирующую функцию типа =СУММ(B2:C4) и получить по нему общий итог.
Если бы нам потребовались операции посложнее примитивной суммы, например, извлечение уникальных значений или Топ-3, то пришлось бы вводить нашу формулу как формулу массива, используя сочетание клавиш Ctrl+Shift+Enter.
Теперь всё по-другому.
Теперь после ввода такой формулы мы можем просто нажать на Enter - и получить в результате сразу все значения, на которые мы ссылались:
Это не магия, а новые динамические массивы, которые теперь есть в Microsoft Excel. Добро пожаловать в новый мир :)
Особенности работы с динамическими массивами
Технически, весь наш динамический массив хранится в первой ячейке G4, заполняя своими данными необходимое количество ячеек вправо и вниз. Если выделить любую другую ячейку массива, то в строке формул ссылка будет неактивной, показывая, что мы находимся в одной из "дочерних" ячеек:
Попытка удалить одну или несколько "дочерних" ячеек ни к чему не приведёт - Excel тут же заново их вычислит и заполнит.
При этом ссылаться на эти "дочерние" ячейки в других формулах мы можем совершенно спокойно:
Если нам нужно переместить массив, то достаточно будет перенести (мышью или сочетанием Ctrl+X, Ctrl+V), опять же, только первую главную ячейку G4 - вслед за ней перенесется на новое место и заново развернётся весь наш массив.
Если вам нужно сослаться где-нибудь еще на листе на созданный динамический массив, то можно использовать спецсимвол # ("решётка") после адреса его ведущей ячейки:
Например, теперь можно легко сделать выпадающий список в ячейке, который ссылается на созданный динамический массив:
Ошибки динамических массивов
Но что будет, если для развёртывания массива не будет достаточно пространства или на его пути окажутся ячейки уже занятые другими данными? Знакомьтесь с принципиально новым типом ошибок в Excel - #ПЕРЕНОС! (#SPILL!):
Как всегда, если щелкнуть мышью по значку с желтым ромбом и восклицательным знаком, то мы получим более подробное пояснение по источнику проблемы и сможем быстро найти мешающие ячейки:

Аналогичные ошибки будут возникать, если массив выходит за пределы листа или натыкается на объединенную ячейку. Если удалить препятствие, то всё тут же исправится на лету.
Динамические массивы и "умные" таблицы
Если динамический массив указывает на "умную" таблицу, созданную сочетанием клавиш Ctrl+T или с помощью Главная - Форматировать как таблицу (Home - Format as Table), то он также унаследует её главное качество - автоподстройку размеров.
При добавлении новых данных внизу или справа "умная" таблица и динамический диапазон тоже будут автоматически растягиваться:
При этом, однако, есть одно ограничение: мы не можем использовать ссылку на динамический диапазон в форумулах внутри "умной" таблицы:
Динамические массивы и другие функции Excel
Хорошо, скажете вы. Всё это интересно и забавно. Не нужно, как раньше, вручную протягивать формулу со ссылкой на первую ячейку исходного диапазона вниз и вправо и всё такое. И всё?
Не совсем.
Динамические массивы - это не просто еще один инструмент в Excel. Теперь они внедрены в самое сердце (или мозг) Microsoft Excel - его вычислительный движок. А это значит что и другие, привычные нам формулы и функции Excel теперь тоже поддерживают работу с динамическими массивами. Давайте разберём несколько примеров, чтобы вы осознали всю глубину произошедших изменений.
Транспонирование
Чтобы транспонировать диапазон (обменять местами строки и столбцы) в Microsoft Excel всегда имелась встроенная функция ТРАНСП (TRANSPOSE). Однако, чтобы её использовать, вы должны были сначала правильно выделить диапазон для результатов (например, если на входе был диапазон 5х3, то вы должны были обязательно выделить 3x5), потом ввести функцию и нажать сочетание Ctrl+Shift+Enter, т.к. она умела работать только в режиме формул массива.
Теперь можно просто выделить одну ячейку, ввести в нее эту же формулу и нажать на обычный Enter - динамический массив сделает всё сам:
Таблица умножения
Этот пример я обычно приводил, когда меня просили наглядно показать преимущества формул массива в Excel. Теперь чтобы посчитать всю таблицу Пифагора достаточно встать в первую ячейку B2, ввести туда формулу перемножающую два массива (вертикальный и горизонтальный набор чисел 1..10) и просто нажать на Enter:
Склейка и преобразование регистра
Массивы можно не только перемножать, но склеивать стандартным оператором & (амперсанд). Предположим, нам нужно сцпеить имя и фамилию из двух столбцов и поправить скачущий регистр в исходных данных. Делаем это одной короткой формулой, которая формирует весь массив, а потом применяем к нему функцию ПРОПНАЧ (PROPER), чтобы привести в порядок регистр:
Вывод Топ-3
Предположим, что у нас есть куча чисел, из которых нужно вывести три лучших результата, расположив их в порядке убывания. Теперь это делается одной формулой и, опять же, без всяких Ctrl+Shift+Enter как раньше:
Если захочется, чтобы результаты располагались не в столбец, а в строку, то достаточно заменить в этой формуле двоеточия (разделитель строк) на точку с запятой (разделитель элементов внутри одной строки). В англоязычной версии Excel роль этих разделителей играют точка с запятой и запятая, соответственно.
ВПР извлекающая сразу несколько столбцов
Функцей ВПР (VLOOKUP) теперь можно вытаскивать значения не из одного, а сразу из нескольких столбцов - достаточно указать их номера (в любом желаемом порядке) в виде массива в третьем аргументе функции:
Функция СМЕЩ (OFFSET) возвращающая динамический массив
Одной из самых интересных и полезных (после ВПР) функций для анализа данных является функция СМЕЩ (OFFSET), которой я посвятил в своё время целую главу в своей книжке и статью здесь. Сложность в понимании и освоении этой функции всегда была в том, что она возвращала в качестве результата массив (диапазон) данных, но увидеть его мы не могли, т.к. Excel до сих пор не умел работать с массивами "из коробки".
Сейчас эта проблема в прошлом. Посмотрите, как теперь с помощью одной формулы и динамического массива, возвращаемого СМЕЩ, можно извлечь все строки по заданному товару из любой отсортированной таблицы:
Давайте разберём её аргументы:
- А1 - стартовая ячейка (точка отсчёта)
- ПОИСКПОЗ(F2;A2:A30;0) - вычисление сдвига от стартовой ячейки вниз - до первой найденной капусты.
- 0 - сдвиг "окна" вправо относительно стартовой ячейки
- СЧЁТЕСЛИ(A2:A30;F2) - вычисление высоты возвращаемого "окна" - количества строк, где есть капуста.
- 4 - размер "окна" по горизонтали, т.е. выводим 4 столбца
Новые функции для динамических массивов
Помимо поддержки механизма динамических массивов в старых функциях, в Microsoft Excel были добавлены несколько совершенно новых функций, заточенных именно под работу с динамическими массивами. В частности, это:
- СОРТ (SORT) - сортирует входной диапазон и выдает динамический массив на выходе
- СОРТПО (SORTBY) - умеет сортировать один диапазон по значениям из другого
- ФИЛЬТР (FILTER) - извлекает из исходного диапазона строки, удовлетворяющие заданным условиям
- УНИК (UNIQUE) - извлекает из диапазона уникальные значения или убирает повторы
- СЛМАССИВ (RANDARRAY) - генерит массив случайных чисел заданного размера
- ПОСЛЕД (SEQUENCE) - формирует массив из последовательности чисел с заданным шагом
Подробнее про них - чуть позже. Они стоят отдельной статьи (и не одной) для вдумчивого изучения :)
Выводы
Если вы прочитали всё написанное выше, то, думаю, уже осознаёте масштаб изменений, которые произошли. Очень многие вещи в Excel теперь можно будет делать проще, легче и логичнее. Я, признаться, немного в шоке от того, сколько статей теперь придется корректировать здесь, на этом сайте и в моих книгах, но готов это сделать с легким сердцем.
Подбивая итоги, в плюсы динамических массивов можно записать следующее:
- Можно забыть про сочетание Ctrl+Shift+Enter. Теперь Excel не видит различий между "обычными формулами" и "формулами массива" и обрабатывает их одинаково.
- Про функцию СУММПРОИЗВ (SUMPRODUCT), которую раньше использовали для ввода формул массива без Ctrl+Shift+Enter тоже можно забыть - теперь достаточно просто СУММ и Enter.
- Умные таблицы и привычные функции (СУММ, ЕСЛИ, ВПР, СУММЕСЛИМН и т.д.) теперь тоже полностью или частично поддерживают динамические массивы.
- Есть обратная совместимость: если открыть книгу с динамическими массивами в старой версии Excel, то они превратятся в формулы массива (в фигурных скобках) и продолжат работать в "старом стиле".
Нашлось и некоторое количество минусов:
- Нельзя удалить отдельные строки, столбцы или ячейки из динамического массива, т.е. он живёт как единый объект.
- Нельзя сортировать динамический массив привычным образом через Данные - Сортировка (Data - Sort). Для этого есть теперь специальная функция СОРТ (SORT).
- Динамический диапазон нельзя превратить в умную таблицу (но можно сделать динамический диапазона на основе умной таблицы).
Само-собой, это еще не конец и, я уверен, Microsoft продолжит совершенствовать этот механизм в будущем.
Где скачать?
И, наконец, главный вопрос :)
Microsoft впервые анонсировало и показало превью динамических массивов в Excel еще в сентябре 2018 года на конференции Ignite. В последующие несколько месяцев происходило тщательное тестирование и обкатка новых возможностей сначала на кошках сотрудниках самой Microsoft, а потом на добровольцах-тестировщиках из круга Office Insiders. В этом году обновление, добавляющее динамические массивы стали постепенно раскатывать уже по обычным подписчикам Office 365. Я, например, получил его только в августе с моей подпиской Office 365 Pro Plus (Monthly Targeted).
Если в вашем Excel ещё нет динамических массивов, а поработать с ними очень хочется, то есть следующие варианты:
- Если у вас подписка Office 365, то можно просто продождать, пока до вас дойдет это обновление. Как быстро это случится - зависит от настройки частоты доставки обновлений для вашего Office (раз в год, раз в полгода, раз в месяц). Если у вас корпоративный ПК, то можно попросить вашего администратора настроить загрузку обновлений почаще.
- Можно записаться в ряды тех самых добровольцев-тестировщиков Office Insiders - тогда вы будете первым получать все новые возможности и функции (но есть шанс повышенной глючности в работе Excel, само-собой).
- Если у вас не подписка, а коробочная standalone-версия Excel, то придется ждать до выхода следующей версии Office и Excel в 2022 году, как минимум. Пользователи таких версий получают только обновления безопасности и исправления ошибок, а все новые "плюшки" теперь достаются только подписчикам Office 365. Sad but true :)
В любом случае, когда динамические массивы появятся в вашем Excel - после этой статьи вы будете к этому уже готовы :)
Ссылки по теме
- Что такое формулы массива и как их использовать в Excel
- Суммирование по окну (диапазону) с помощью функции СМЕЩ (OFFSET)
- 3 способа транспонировать таблицу в Excel
Интересно, это сколько новых идей и практического применения вызовет использование динамических массивов?
Николай, на счёт переписать 2-ю книжку Вы, конечно, пошутили... Или нет?
Вначале говорю Вам Спасибо, за такую замечательную новость!
И хочу спросить - какая у Вас версия Excel сейчас? Сегодня купил Office 365 (правда пока проверил на MacOS) - нет динамических массивов
Моя версия Excel 16.29 (19090802)
Кстати, для Мака их может еще и не быть.
Напишите пожалуйста какая у вас версия офиса и сборка.
PS: Я правильно понимаю, что эта ваша версия в рамках подписки и вы не состоите в Office Insider?
Не Office Insider
Достучался через IT до Microsoft, сказали что для нас добавление новых функций запланировано на конец Q1'2020.
Теперь в томительном ожидании.
Которая сильно запаздывает и пропускает некоторые версии.
Например мы с версии 19.02 сразу идем в 19.08, а потом 19.09 которую нам должны накатить только в конце июня 2020.
Октябрь 2020 замечательный месяц, нам наконец то накатили обновление в котором есть динамические массивы.
Была 1908 и сейчас нам поставили 2002.
В итоге вместо Q1'20 все сместилось на Q4'20
PS: Немного поправлю функция "НАИБОЛЬШИЙ" в английской версии "LARGE"
PPS: Да версия конечно же у нас не отдельная
у меня Microsoft Office 365 ProPlus
Версия 1909 (сборка 12026.20264) Monyhly Channel
Если смотреть "о программе Excel" то Microsoft Excel для Office 365 MSO (16.0.12026.20100) 32-разрядная
новых плюшек до сих порт нет.
ЗЫ. Можете попробовать пнуть админов, чтобы переключили вас на Monthly (Targeted) канал обновлений. Если это у вас возможно и приемлемо. Всётаки, Targeted-каналы - это всё ещё тестовые версии, которые не обязаны быть стабильными.
Офис купил только после просмотра Вашего видео, до этого у меня стоял ломанный Excel 2016.
Чем я обидел майкрасофт??? Почему мне не дают эту "магию". И почему Вы работаете на благо и приводите клиентов, а Майкрасофт Вас подводит???
Есть ли Excel способ задать какие либо ограничения по округлений данных по месяцам, чтобы их сумма не превышала или не была ниже заданного округлённого годового значения?
Спасибо
Как объединить два и более динамических массива в один?
Имеется номенклатура в нескольких столбцах, хотел построить отсортированный список без дубликатов динамическим массивом
Можно собрать одну таблицу с нескольких листов при помощи динамических массивов?
Спасибо!
Не могу только решить одну, часто встречающуюся у меня в работе, задачу.
Есть 2 массива с одинаковым количеством столбцов. В первом 1 строка, а во втором может быть очень много. Нужно на выходе получить массив, в котором в каждой строке должен получиться сумма произведений строки из первого массива и поочередно строк второго.
Уже все перепробовал, возможно есть способ. Заранее спасибо за ответ.
При использовании динамических массивов столкнутся с проблемой, когда при розшаревании файла все формулы с динамическими массивами превращаются в обычные формулы массивов.
Не могу найти никакой информации по этому вопросу. Как это влияет на производительность и можно ли этого избежать.
Может вы что-то подскжете?
[img][/img]
Вопрос по: Функция СМЕЩ (OFFSET) возвращающая динамический массив
Если по столбцу Товар какая нибудь позиция будет только в единственном числе, то на выходе эта позиция дублируется на весь массив. Как можно исправить такую ошибку?
Подскажите пожалуйста.
Работает только такая запись на объединение динамических таблиц:
=a2#:b2#
то есть, a2# и b2# можно горизонтально пристыковать.
Неожиданности граничащие с багом, например объединить две таблицы с зазором:
a2# и s2# содержат сходные таблицы, если между ними есть столбцы, то есть в шве есть еще данные (или просто пустые столбцы-ячейки), то запись =a2#:s2# создаст общую таблицу с данными шва между a2# и s2#, пустые ячейки шва заполняются нулями.
Так же запись =s2#:a2# работает не правильно, на первое место ставится то, что слева, то есть работает как =a2#:s2#
=СУММЕСЛИ(B2#;B2#;F2#)
B2# - столбец с датами, иногда повторяются
F2# - столбец с данными, которые нужно суммировать по датам напротив дат
Запись типа
=СУММЕСЛИ(ГОД(F13#);ГОД(F13#);G13#)
=СУММЕСЛИ(МЕСЯЦ(F13#)&"."&ГОД(F13#);МЕСЯЦ(F13#)&"."&ГОД(F13#);G13#)
опознается ошибкой с предложением исправить что-либо в формуле.
=ЕСЛИ(И(C49#>12;C49#<16);820;1020)
не "вытекает", отображает только первую ячейку
работает, то есть "вытекает" так:
=ЕСЛИ((C49#>12)*(C49#<16);820;1020)
Подскажите, пожалуйста, есть ли возможность расположить динамические массивы один под другим, с тем условием, что они находятся на разных листах? т.е. на листах я собираю (подготавливаю) таблицы, а затем, для расчетов мне нужна сводная. Использую динамические, потому что размеры таблиц по количеству строк всегда меняются. Может быть есть какой-то другой способ (кроме Power Q)?
Работает только такая запись на объединение динамических таблиц:
=a2#:b2#
то есть, a2# и b2# можно горизонтально пристыковать.
Условия: таблицы имеют одинаковое количество столбцов и расположены строго друг под другом (при этом количество пустых строк между таблицами не имеет значения).
=ФИЛЬТР(C2#:C17#:C27#;ИНДЕКС(C2#:C17#:C27#;;1)>0), соответственно в первом столбце изначальных таблиц буду указывать нужна строка в своде или нет, Таблицу C17# можно не рассматривать - она и так попадет.
Они же все возвращают динамический диапазон
И вот вопрос: как вернуть как было раньше? мне не нужен автоматический динамический диапазон, если я ссылаюсь на объединенные ячейки.
Будет ли переписана книга "Книга "Microsoft Excel: Мастер Формул" с учетом появления динамических массивом и если да - то когда ждать новое издание?