Сохранение в Excel из WEB-клиента

20.07.16

Интеграция - Загрузка и выгрузка в Excel

Не всегда корректно отрабатывает сохранение в Excel из 1C при работе в WEB-клиенте. Мне попалась ситуация, когда не отрабатывал код "ТабличныйДокумент.Записать(...)" и выдавалась ошибка "неизвестная ошибка.: object doesn't support this property or method" Ниже предложена процедура сохранения в Excel, корректно работающая во всех типах подключения.

Суть метода в том, что при работе в WEB-клиенте сохранение в Excel происходит на сервере, а потом файл передается клиенту через временное хранилище.

 

//***********************************************************************
&НаКлиенте
Процедура СохранитьВExcel(ТабличныйДокумент)

   
ИмяФайла = "Имя отчета" + " (" +
   
Строка(Формат(ТекущаяДата(),"ДФ=""дд-ММ-гггг""")) + ")"
   
+".xlsx";

   
#Если ВебКлиент Тогда
       
//Подключим расширение работы с файлами
       
Если Не ПодключитьРасширениеРаботыСФайлами() Тогда
           
УстановитьРасширениеРаботыСФайлами();
           
ПодключитьРасширениеРаботыСФайлами();
        КонецЕсли;
   
#КонецЕсли

   
//Вызовем диалог сохранения файла
   
ВыборФайла = Новый ДиалогВыбораФайла(РежимДиалогаВыбораФайла.Сохранение);
   
ВыборФайла.Заголовок = "Укажите каталог и название файла для сохранения.";
   
ВыборФайла.ПолноеИмяФайла = ИмяФайла;
    Если
ВыборФайла.Выбрать() Тогда

       
#Если ВебКлиент Тогда
           
//Получим адрес временного хранилища с файлом или сообщение об ошибке
           
АдресХранилищаИлиОшибка = "";
            Если
СформироватьФайлОтчетаНаСервере(ТабличныйДокумент,ИмяФайла,АдресХранилищаИлиОшибка) Тогда
               
ПолучаемыеФайлы = Новый Массив;
               
ПолучаемыеФайлы.Добавить(Новый ОписаниеПередаваемогоФайла(ИмяФайла,АдресХранилищаИлиОшибка));
               
ПолученныеФайлы = Новый Массив;
               
//Получим файл
               
Если НЕ ПолучитьФайлы(ПолучаемыеФайлы, ПолученныеФайлы, ВыборФайла.Каталог, Ложь) Тогда
                   
Сообщить("Ошибка передачи файла отчета с сервера.", СтатусСообщения.Важное);
                    Возврат;
                КонецЕсли;
            Иначе
               
Сообщить(АдресХранилищаИлиОшибка);
                Возврат;
            КонецЕсли;
       
#Иначе
           
//Сохраним файл
           
Попытка
               
Результат.Записать(ВыборФайла.ПолноеИмяФайла,ТипФайлаТабличногоДокумента.XLSX);
            Исключение
               
Сообщить("Не удалось сохранить документ в файл " + ИмяФайла
                + Символы.ПС + ОписаниеОшибки(), СтатусСообщения.Важное);
                Возврат;
            КонецПопытки;
       
#КонецЕсли

   
КонецЕсли;

КонецПроцедуры


//***********************************************************************
&НаСервере
Функция СформироватьФайлОтчетаНаСервере(ТабличныйДокумент, ИмяФайла, АдресХранилищаИлиОшибка="")

   
//Сформируем полное имя файла
   
ПолноеИмяФайла = КаталогВременныхФайлов() + ИмяФайла;

   
//Сохранение и передача файла
   
Попытка
       
//Запишем табличный документ в файл
       
ТабличныйДокумент.Записать(ПолноеИмяФайла, ТипФайлаТабличногоДокумента.XLSX);
       
//Вернем на клиент двоичные данные файла
       
АдресХранилищаИлиОшибка = ПоместитьВоВременноеХранилище(Новый ДвоичныеДанные(ПолноеИмяФайла));
        Возврат Истина;
    Исключение
       
АдресХранилищаИлиОшибка = "Не удалось сохранить документ в файл " + ИмяФайла
        + Символы.ПС + ОписаниеОшибки();
        Возврат Ложь;
    КонецПопытки;

КонецФункции

 

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

Вступайте в нашу телеграмм-группу Инфостарт

Excel WEB сохренить

Вы можете заказать платную адаптацию этой статьи под ваши задачи на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

См. также

Загрузка и выгрузка в Excel Розничная торговля Логистика, склад и ТМЦ Ценообразование, анализ цен Прайсы Системный администратор Программист 1С:Предприятие 8 1С:Комплексная автоматизация 1.х 1С:Розница 2 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Управленческий учет Платные (руб)

Загрузка номенклатуры из файлов Excel (xls, xlsx, ods, csv, mxl) в УТ11, КА 2, ERP 2, Розница 2. Задействованы все возможности конфигурации - заполнение реквизитов номенклатуры, дополнительных реквизитов и сведений, характеристики, доп.реквизиты и сведения характеристик. Дополнительные обработки для расширения возможностей.

12444 руб.

29.10.2014    233225    753    536    

501

Загрузка и выгрузка в Excel Маркетплейсы Программист Бухгалтер Пользователь 1С:Предприятие 8 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Бухгалтерский учет Управленческий учет Платные (руб)

Загружает данные из Акта приемки товара от ООО «Вайлдберриз», полученный из личного кабинета в формате *.xlsx или API в документ "Реализация (акты, накладные, УПД)" для конфигурации: Бухгалтерия предприятия, редакция 3.0, в документ "Реализация товаров и услуг" для Управление торговлей, редакция 11; Комплексная автоматизация 2; ERP 2 Управление предприятием и в документ "Расходная накладная" для Управление нашей фирмой 3.0; Розница 3.0

6100 руб.

24.01.2021    25077    122    0    

63

Загрузка и выгрузка в Excel Логистика, склад и ТМЦ Ценообразование, анализ цен Файловый обмен (TXT, XML, DBF), FTP Бухгалтер Пользователь 1С:Предприятие 8 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Эволюция не стоит на месте - новая удобная версия функциональной обработки для Вашего бизнеса! Что же Вы получаете? Удобный и интуитивно понятный интерфейс с 3-мя этапами работы. 2 режима - автоматический и ручной. Чтение XLSX, XLSM, CSV, XML/YML форматов без офиса, на любом сервере! Визуальное связывание колонок файла и реквизитов простым перетаскиванием колонок. Создание или обновление номенклатуры с иерархией, характеристик, доп. реквизитов, упаковок, загрузка практически неограниченного количества картинок на одну номенклатуру (с возможностью загрузки в несколько потоков одновременно), с хранением в томах или в базе. Загрузка номенклатуры поставщиков или поиск по их данным номенклатуры. Загрузка доп. реквизитов в характеристики. Загрузка штрихкодов с генерацией новых. Создание элементов справочников и ПВХ "на лету" для выбранных реквизитов. (Обновление от 14.05.2026, версия 9.3.1 - 10.7.2)

20740 руб.

20.11.2015    175715    427    397    

544

Загрузка и выгрузка в Excel Программист Бухгалтер Пользователь 1С:Предприятие 8 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Розничная и сетевая торговля (FMCG) Управленческий учет Платные (руб)

Загрузка данных отчета о реализации товаров из сервиса Lamoda «Ламода» для конфигурации: 1С:Бухгалтерия предприятия, редакция 3.0; 1C:Управление торговлей, редакция 11 и 1C:Управление нашей фирмой, редакция 3.0 в документ "Отчет комиссионера (агента) о продажах".

6100 руб.

01.03.2021    12640    73    0    

31
Для отправки сообщения требуется регистрация/авторизация