Сводная таблица с текстом в значениях

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

Давайте попробуем обойти это ограничение и придумать "пару костылей" в подобной ситуации.

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

Исходные данные и результат

Для удобства, давайте заранее сделаем таблицу с исходными данными "умной" с помощью команды Главная - Форматировать как таблицу (Home - Format as Table) и дадим ей имя Поставки на вкладке Конструктор (Design). В дальнейшем, это упростит жизнь, т.к. можно будет использовать имя таблицы и ее столбцов прямо в формулах.

Способ 1. Самый простой - используем Power Query

Power Query - это супермощный инструмент для загрузки и преобразований данных в Excel. Эта надстройка по умолчанию встроена в Excel начиная с 2016-й версии. Если у вас Excel 2010 или 2013, то ее можно отдельно скачать и установить (совершенно бесплатно).

Весь процесс, для наглядности, я пошагово разобрал в следующем видео:

Если нет возможности использовать Power Query, то можно пойти другими путями - через сводную таблицу или формулы. 

Способ 2. Вспомогательная сводная

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

Добавляем номер строки

Очевидно, что -1 нужен, поскольку у нас в таблице есть однострочная шапка. Если ваша таблица лежит не в начале листа, то можно использовать чуть более сложную, но универсальную формулу, которая вычисляет разницу в номерах текущей строки и шапки таблицы:

Универсальная формула расчета номера строки

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

Сводная с номерами строк

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

Дополнительно можно отключить общие и промежуточные итоги на вкладке Конструктор - Общие итоги и Промежуточные итоги (Design - Grand Totals, Subtotals) и там же переключить сводную в более удобный табличный макет кнопкой Макет отчета (Report Layout).

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

Теперь скопируем сводную (на этот же лист или на другой) и вставим как значения, а затем введем в область значений свою формулу, которая будет извлекать код контейнера по номеру строки, найденному в сводной:

Извлекаем код контейнера по номеру строки в сводной

Функция ЕСЛИ (IF), в данном случае, проверяет, чтобы очередная ячейка в сводной была не пустой. Если пустая, то выводим пустую текстовую строку "", т.е. оставляем ячейку незаполненной. Если не пустая, то извлекаем из столбца Контейнер исходной таблицы Поставки содержимое ячейки по номеру строки с помощью функции ИНДЕКС (INDEX).

Пожалуй, единственным не очень очевидным моментом тут является задвоенное слово Контейнер в формуле. Такая странная форма записи:

Поставки[[Контейнер]:[Контейнер]]

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

В будущем, при изменении данных в исходной таблице Поставки, необходимо не забыть обновить нашу вспомогательную сводную с номерами строк, щелкнув по ней правой кнопкой мыши и выбрав команду Обновить (Refresh).

Способ 3. Формулы

Этот способ не требует создания промежуточной сводной таблицы и ручного обновления, а использует "тяжелое оружие Excel" - функцию СУММЕСЛИМН (SUMIFS). Вместо поиска номеров строк в сводной их можно вычислить с помощью вот такой формулы:

Ищем номера строк функцией СУММЕСЛИМН

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

Сводная с текстом в области значений

Само-собой, в этом случае уже не нужно думать про обновление сводной, но на больших таблицах функция СУММЕСЛИ может ощутимо тормозить. Тогда придется отключать автоматическое обновление формул или же воспользоваться первым способом - сводной таблицей.

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

Ссылки по теме


16.11.2016 19:46:48
А если вместо столбца с номером строки поставить слияние первых трех столбцов (РоссияМоскваянв), то можно привычно через впр подтянуть номера контейнеров.

не так изощеренно, но работает.
18.11.2016 22:47:40
Как всегда шикарно, Николай! ))
21.11.2016 09:07:39
Отлично! Как всегда, ловкое применение стандартных инструментов дает прекрасный результат :)

Я бы решал эту задачу при помощи PowerPivot (это просто, когда знаешь :) :
для конкретно такой формы результата и исходных данных
:=VALUES('Поставки'[Контейнер]),
для возможных повторений или итогов
:=IF(HASONEVALUE('Поставки'[Контейнер]),VALUES('Поставки'[Контейнер]),CONCATENATEX('Поставки','Поставки'[Контейнер],", "))
05.03.2017 21:18:50
Добрый день. Благодаря Вам, решил шире глянуть на мир и решить эту задачу при помощи PowerPivot . Но ничего не получилось :(  В общем не мудрено, поскольку не знаю. Я пишу =VALUES('Таблица'[Поле]) как формулу вычисляемого поля и ничего не получается. Очевидно что-то не так делаю. Буду признателен, если подробнее поясните как достичь цели.
26.01.2017 15:35:34
Здравствуйте, спасибо Вам за детальное обьяснение!
Данные способы я так понимаю работают только в случае отсутствия нескольких значений, которые соответствуют одному и тому же городу и месяцу (как в этом примере).
А что делать, если есть все-таки несколько значений? буду Вам очень благодарна за помощь!!
15.07.2017 15:59:57
Способ 1, который с Power Query может и несколько значений вывести через запятую - см. видео.
14.02.2017 08:20:41
Раньше текст в данных сводной можно было реализовать в старом MS Access
Жаль что эта функция не получила дальнейшего развития
12.04.2017 12:07:51
Использую вложение функции поискпозиции: =ИНДЕКС(отгрузки!A3:I1411;ПОИСКПОЗ(H5&I4;отгрузки!A3:A1411&отгрузки!I3:I1411;0);6), где A:I - массив, H&I - критерии поиска; 0 - точное совпадение; 6 - номер поля искомого значения. Формула массива, поэтому жмём Ctrl+Shift+Enter.
11.07.2017 09:08:31
Подскажите, может есть идеи , как сделать такую же таблицу, но если на одно значение "Россия/москва"  приходится несколько январей с разными контейнерами? Я уже голову себе сломала(
15.07.2017 15:59:02
Ядвига, записал видео про то, как это сделать с помощью Power Query - посмотрите Способ 1 в статье.
11.07.2017 09:33:47
и значения повторяющиеся должны идти в стоке по порядку, то есть на 1 строку "Россия/москва" в следующем столбце - 1 ящик, в 3 столбце - 2й ящик и так далее
17.07.2017 16:56:52
Подскажите, пожалуйста, если при нажатии на значёк в названии пользовательского столбца (со списком ), для извлечения значений списка автоматически разворачивается список, и не появляется меню с возможностью выбора разделителя. Это проблема в формате данных или самого экселя (установлен 2016) и есть ли другие возможности объединить подобным образом записи для двух и более строк имеющих общие данные (как в примере когда в одна страна - разные контейнеры)?
08.12.2017 14:13:18
Существует более простой способ получения столбца со списком кодов контейнеров.
При создании пользовательского столбца ввести формулу:

=Text.Combine([Поставки][Контейнер], ", ")

За данный способ выражаю благодарность Максиму Зеленскому
24.05.2018 15:51:05
с Power Query мега круто! В особенности на том этапе, где не нужно агрегирование. Заткнули за пояс стоковые сводные таблицы
Спасибо за хорошие описание данной задачи!
однако столкнулся с ограничением в Power Query на размеры таблицы.
как с этим бороться?
19.11.2018 13:36:04
Уперлись в предел 16 тыс. столбцов или 2 млрд. строк?
22.11.2018 17:40:24
Спасибо за разъяснения по решению сбора информации кросс-таблицы текстового формата. Но остались вопросы:
1. возможно ли (и каким образом) при переводе в excel, разместить данные на каждой строке (НЕ ячейке)?  При формировании таблицы в Power Query, это возможно сделать на этапе "Извлечения значения", указав при выборе разделителя спец.символ  "Перевод строки". Но при загрузке в Excel, все данные встают в одну строку, без разделителя.
2. каким образом можно собрать таблицу, находящуюся на n-ом кол-ве листов, для дальнейшей работы с ней через PowerQuery
25.11.2018 09:46:12
1. Нажмите для этих ячеек кнопку Перенос по словам на вкладке Главная.
2. В Power Query и собрать. Данные - Создать запрос - Из файла Excel - выбрать нужные листы.
27.11.2018 13:41:42
Спасибо, c переносом разобралась.
Не совсем понятно правильно ли я делаю сбор таблицы. Таблица состоит из листов (1 лист - 1 месяц). Чтобы собрать, я перехожу в Power Query, в меню на Главной выбираю "Создать источник" и выбираю файл, из которого необходимо сделать выгрузку. Далее через "Добавить запрос" выбираю нужное кол-во таблиц и создаю единую базу. И уже потом могу работать с образованной объеденной базой. Но есть вопрос:
Как выгрузить только объеденную базу? У меня при загрузке в Excel выгружаются все листы из которых создавалась база + новая созданная единая база.  
20.12.2018 16:23:07
Я так сильно не заморачиваюсь.
Нажимаю параметры поля, там есть вкладка "Разметка и печать" и когда добавляю строки в сводную таблицу, у каждого поля на этой вкладке отмечаю "В виде таблицы" и все даты выводятся датами (при необходимости словами) и слова выводятся текстом.
03.06.2019 18:39:34
Спасибо за видео! Очень полезное, у меня другая проблема во всех сводках съедает в Индексах (текстовых) нули. То есть если я вставляю в эксель вообще индекс необходимый 00772 то в ячейке все время 772 как не крути((, а так хотелось бы ВПРом сравнить индексы! Подскажите пожалуйста, как научить эксель не съедать нули в текстовом значении, в начале и конце. Спасибо
11.07.2019 16:14:22
К сожалению, таблицы, в которых мы получаем текстовые значения автоматически не обновляемые...т.е. если мы в таблицу данных добавляем еще данные, то в сделанной таблице с текстовыми значениями ничего не прибавляется и приходится вручную опять копировать сводную и прописывать формулы...
или я что-то не так сделала...
18.12.2019 12:20:41
Нажимаю закрыть и загрузить
предлагает только два варианты загрузки
1) Таблица
2) Только создать подключение
сводную таблицу выгрузить не предлагает
Excel 2016
02.03.2020 19:59:40
Николай, подскажите, пожалуйста...Если номер контейнера содержит запятую (3GQ,794), то PowerQuery в области значений заключает его в кавычки ("3GQ,794",CPK-333). Вопрос: можно ли этого избежать, т.е. чтобы получилось (3GQ,794,CPK-333)? Спасибо.
29.03.2020 08:24:45
Добрый день, помогите справиться с такой проблемой - установлен офис 2016,( проф.+). В PowerQuery из таблицы передаю данные в запрос, --> в идеале должна создаваться таблица, в заголовках значки "АВС". У меня просто названия столбцов, может из-за этого не корректно работает функция развертывания пользовательского столбца в значения через запятую, у меня при нажатии на значок в верхнем правом углу сразу развертывается таблица без группировки, меню выбора вариантов нет (т.е. сразу отрабатывается 1 строка меню, какое у Вас на видео). Пробовала загрузить Ваш пример - сообщение, что у Вас более новая версия PowerQuery. Обновить нельзя - обновление только для 2010, 2013. Что Вы мне посоветуете предпринять для решения этой проблемы. Спасибо
25.08.2020 04:42:46
Добрый день!
А можно на данную таблицу ещё наложить фильтр по какому-то столбцу, чтобы пользователь мог фильтровать какую-то категорию и данные менялись?
25.08.2020 08:41:46
Николай, здесь добавил в ваш пример решение данной задачи при помощи сводной на базе модели данных Power Pivot.
05.04.2021 06:24:41
Добрый день! Подскажите пожалуйста, у меня есть таблица только с текстовыми данными, мне нужно провести вычисления в сводной таблице, разделить, например, поле "А" на поле "Б", грубо говоря, вычислить долю "Б" в "А", как при этом избежать ошибку #ДЕЛ/0?[img][/img]
07.08.2021 07:41:24
Доброго всем времени суток. Я новый член вашего клуба. :)Вчера ознакомилась с видеоуроком по созданию кросс-таблицы - в общем это мой вариант и нужно ее создать очень-очень. Сегодня делаю, но...вот такая выходит ошибка после сохранения введенных мною параметров в редакторе запросов:
Expression.Error: Не удается преобразовать значение null в тип Text.
Подробные сведения:
   Value=
   Type=Type


Могу я с это как-то побороть?
14.11.2021 00:01:18
Если  тема еще  актуальна, то текст  в область значений выводится следующим образом:
1) добавляем таблицу в модель денных
2) делаем сводную
3 ) создаем меру в которую записываем следующую  формулу на dax :
=CONCATENATEX(Values(Table[Column]), Table[Column], ", ")
где table - название  сводной, column название столбца  откуда нужно вывести текст в область значений
4) добавляем меру в область значений.
03.02.2023 01:00:32
Очень спасибо. Прям выручило при добавлении комментариев к сводной.
12.01.2022 16:37:02
Здравствуйте, Николай! Спасибо большое за видеоурок.
Хотела бы уточнить, данный способ позволяет из каких-либо столбцов делать фильтр (как в сводной таблице) или нет?
Хотелось бы, например, в своде увидеть фильтр по стране в левом углу и возможностью выбрать страну.
20.03.2022 15:28:20
да, фильтры есть. Сможете. Пробуйте
20.03.2022 15:26:37
Добрый день! Очень и очень полезное видео. почти все получилось, но возможно не хватает предобработки данных. Пишет, что "Expression.Error] Не удается преобразовать значение #datetime(2022, 3, 2, 0, 0, 0) в тип Text." при возвращении к исходным данным и попытке преобразовать их в текстовый формат все отображается правильно как текст. Но при обновлении данных в таблице ошибка не разрешается. Перенаправьте меня, пожалуйста, к статье, которая может мне помочь. Предполагаю, что дело в последовательности обработки исходных данных.
MEP
16.08.2023 13:22:03
Добрый день. у меня пример по работе похожий на 1 кейс, но  там еще информация по стоимостям, которые желательно видеть суммой помесячно под каждым контейнером (т.е. как бы получается контейнеры через запятую разбиты по месяцам, а деньги в строке снизу также разбиты по месяцам). хотят сразу видеть и физику и деньги. можете помочь как настроить группировку или агрегирование под доп вычисления ?
MEP
16.08.2023 13:55:44
добрый день. у меня в исходных данных (подобных в примере 1) есть еще стоимости, которые надо разнести под строками с перечислением контейнеров. как это сделать в Power Query подскажите пожалуйста
MEP
16.08.2023 14:08:02
Добрый день. У меня пример, похожий на этот кейс но есть еще стоимости контейнеров, котрые также надо агрегировать суммой и отбразить под перечислением контейнеров. как это сделать? помогите пожалуйста
Наверх