Решил развенчать мифы по поводу "тормознутости" технологии COM при работе с Microsoft Excel и оперировании большими объемами данных.
Большими объемами данных в данном случае будет считаться матрица 50к х 20 элементов, т.е. 1Миллион элементов.
Для этого была создана простейшая обработка (проверена на платформе 8.3.14.1565), которая один и тот же табличный файл может читать как с привлечением MS Excel на клиенской машине, так и с помощью нативной возможности платформы 1С 8.х, появившейся уже достаточно давно.
Итак, первым в забеге был MS EXCEL.
Т.к. тест проводился в клиент-серверной базе, и на сервере приложения 1С не установлен MS Excel, то в данном случае придется передавать большой объем данных с клиента 1С на сервер 1С.
Результаты теста следующие:
Выделенные строки - это ЧИСТОЕ время формирования ТЗ на 1миллион значений. Чистое время составляет 0.785961 секунды. Время получения самого массива данных из MS Excel в 1С:
Т.е. 0.557474 секунды.
ИТОГО: 0.595377(создание COM-объекта MS EXCEL) + 0.472448(открытие файла) + 0.785961 + 0.557474 = 2.41126 секунды.
Время на передачу массива между клиентом и сервером не считаем, т.к. на сервере 1С установлен MS Excel.
Вторым был нативный метод чтения табличных документов платформой 1С.
Т.к. тест проводился в клиент-серверной базе, в данном случае придется передавать сам файл с клиента 1С на сервер 1С. Время передачи файла - 0.770753 секунды.
Результаты теста следующие:
Выделенные строки - это ЧИСТОЕ время формирования ТЗ на 1миллион значений. Чистое время составляет 22.394099 секунд.
ИТОГО: 0.770753(время на передачу файла с клиента 1С на сервер 1С) + 15.752302(время на чтение табличного документа из файла) + 22.394099 секунд = 38.917154 секунды.
Внимательный читатель спросит: "почему при чтении через COM не учитывается время на передачу файла с клиента 1С на сервер?"
Ответ: Вносим корректировки в результаты.
Вариант1:
ВремяПередачиФайлаСКлиентаНаСервер = 0.770753 секунды
ОбщееВремяФормированияТЗ = 2.41126 секунды
Итого: 0.770753 секунды + 2.41126 секунды = 3.182013 секунды
Мораль сей басни такова: не стесняйтесь использовать Microsoft Excel на сервере 1С - это ЗАМЕТНО увеличивает скорость выгрузки/загрузки данных в/из табличных документов.