Skip to content

небольшая надстройка, предназначенная для оценки скорости выполнения запросов PQ и формул на листах в среде MS Excel в среде MS Excel

License

Notifications You must be signed in to change notification settings

buchlotnik/Merka

Repository files navigation

Мерка

небольшая надстройка, предназначенная для оценки скорости выполнения запросов PQ и формул в среде MS Excel

Системные требования

  • Excel 2016 и новее (по отзывам работает также и 2013, с точки зрения кода - работать будет и в 2010, но непосредственное тестирование автором не проводилось)
  • Разрешённые макросы

Установка

Приложение поставляется в виде единственного файла Мерка_версия.xlam

Надстройку можно добавить одним из способов:

  • Использовать стандартный путь Файл - Параметры - Надстройки - Надстройки Excel - Перейти... - Обзор - и выбрать расположение файла
  • Поместить файл в директорию с надстройками C:\Users\User\AppData\Roaming\Microsoft\AddIns - тогда Мерка появится в списке доступных надстроек
  • Поместить файл (или его ярлык) в папку C:\Users\User\AppData\Roaming\Microsoft\Excel\XLSTART - в этом случае надстройка будет запускаться в автоматическом режиме при запуске Excel

После установки вам станут доступны:

  • Вкладка Мерка на ленте Группа надстройки
  • Группа Мерка и кнопки запросы и формулы на вкладке Данные
  • Макрос load_merka, доступный при настройке панели быстрого доступа

Модуль "запросы"

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

Список запросов:

  • N - номер в списке
  • Название запроса - полное или очищенное название запроса
  • Тип - тип подключения, оценить скорость можно только у подключений типа 1 - xlConnectionTypeOLEDB (модель - это тип 7, запросы без источника - 9)
  • Диапазонов - запросы, загруженные на лист, имеют один диапазон, только подключения - ноль
  • В модели - отображает, загружается ли запрос в модель данных

Настраиваемые праметры:

  • необходимое число итераций - количество циклов измерения скорости выполнения запросов
  • число холостых прогонов - количество циклов обновления запроса до начала измерения

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

  • выгрузка - по умолчанию выгрузка результатов осуществляется на новый лист, при необходимости можно указать диапазон на активном листе, начиная с которого нужно выгружать результаты
  • показывать только выгружаемые запросы - механика приложения позволяет оценить скорость только тех запросов, которые реально выгружаются на лист или загружаются в модель данных, при активации флажка из списка будут исключены запросы со статусом "только подключение" и функции
  • очищать названия запросов - в списке подключений запросы получают префикс "Запрос - " или "Query - ", что не соответствует отображаемым именам в окне "запросы и подключения", при активации флажка префиксы удаляются из названий
  • создавать таблицу и сводную - при активации флажка после завершения измерения скорости и выгрузки результатов на лист результаты будут отформатированы как Таблица с именем Мерка_DataX (где X - номер добавленной таблицы, нумерация начинается с нуля, номер изменяется при каждом следующем запуске измерения) и будет сформирована сводная таблица, в которой выводится статистика по проанализированным запросам Общий вид выгружаемых данных
  • добавить рисунок сводной - при активном флажке помимо сводной таблицы будет создаваться её копия в виде рисунка, помещается рядом на листе. опция нужна, если вы собираетесь делиться результатами на форумах или в телеграм-каналах
  • показывать вкладку Мерка - при активном флажке вкладка отображается
  • кнопка на вкладке Данные - при активном флажке во вкладке Данные отображается дополнительная группа Мерка

Важно: настройки вкладки и кнопки вступают в силу после перезапуска приложения или при открытии нового файла

Не менее важно: если вы скрыли обе кнопки, а запустить надстройку всё-таки необходимо - используйте макрос load_merka с панели быстрого доступа

Кнопки:

  • Начать измерение - запустит процесс узмерения
  • Закрыть - закроет форму
  • Сохранить настройки - сохранит текущее состояние флажков и текстовых полей (настройки хранятся в самом файле Мерка_версия.xlam, настройки общие для обоих модулей)
  • RU EN - переключение между языками интерфейса - актуально и для русскоязычных пользователей при работе в другой локали
  • выбрать все - выберет для анализа все запросы в списке на экране
  • убрать выделение - снимет выделение со всех запросов на экране

Общие замечания по использованию

  • проанализировать можно только те запросы, которые реально выгружаются на лист или в модель данных
  • оценить скорость выполнения отдельных шагов запроса, как в PBI, с текущей механикой приложения невозможно
  • на скорость обновления запросов влияет нагруженность вашего процессора в целом, поэтому не следует, запустив процесс анализа, параллельно запускать игрульки или видосики с интернета
  • для повышения корректности результатов рекомендуется делать холостые прогоны (в ранних версиях это было установкой по умолчанию, но поскольку существуют ситуации, когда выполнение запроса занимает минуты и десятки минут, опция стала доступной)

Модуль "формулы"

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

Список диапазонов

  • сюда просто вводим необходимые адреса, или выделяем мышкой с зажатым ctrl или просто выделяем диапазон ячеек - проанализированы будут все ячейки с формулами в указанных диапазонах

Настраиваемые праметры:

  • кругов по - количество циклов измерения скорости выполнения формулы
  • итераций каждый - количество итераций в пределах одного цикла - в зависимости от сложности формулы для получения осмысленных результатов требуется от 100 до 10000 итераций

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

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

Общие замечания по использованию

  • анализируются только ячейки, содержащие формулы
  • в текущем варианте происходит пересчёт каждой ячейки независимо

Автор

buchlotnik - обитаю здесь: github, telegram, muzykin.com

Лицензия

Приложение бесплатное с открытым кодом, но для порядку см. LICENSE.md

Ссылка

Исходники всегда лежат на GitHub

About

небольшая надстройка, предназначенная для оценки скорости выполнения запросов PQ и формул на листах в среде MS Excel в среде MS Excel

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published