[ШАБЛОН] Загрузка данных из Excel

04.04.23

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

Шаблон обработки загрузке данных из Excel. Обработка может быть полезна как матерым программистам, так и новичкам. Первые не будут писать код заново, а вторые получают шаблон, с которым можно начинать разбираться с выгрузкой и загрузкой из Excel. Основная задача данного шаблона - сократить время на поиск и написание кода по загрузке данных.

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
[ШАБЛОН] Загрузка данных из Excel :
.epf 7,11Kb
12
12 Скачать (1 SM) Купить за 1 850 руб.

Обработка запускается как внешняя из пользовательского режима.

Выбирается путь к файлу Excel (*.xlsx;*.xls;) и происходит загрузка данных из файла по этому пути. Как таковой загрузки никаких данных тут не происходит, и обработка строк условная. 

Все тесты производились на платформе 8.3.20.1914, однако код отработает на любой из 8.2, 8.3.
 

&НаКлиенте
Процедура ПутьКФайлуНачалоВыбора(Элемент, ДанныеВыбора, СтандартнаяОбработка)
    Режим = РежимДиалогаВыбораФайла.Открытие;
    ДиалогОткрытияФайла = Новый ДиалогВыбораФайла(Режим);
    ДиалогОткрытияФайла.ПолноеИмяФайла = "";
    Фильтр = НСтр("ru = 'Файл XLSX'; en = 'XLSX file'") + "(*.xlsx)|*.xlsx";
    ДиалогОткрытияФайла.Фильтр = Фильтр; 
    ДиалогОткрытияФайла.МножественныйВыбор = Ложь;
    ДиалогОткрытияФайла.Заголовок = "Выберите файл";
    ДиалогОткрытияФайла.Показать(Новый ОписаниеОповещения("ПутьКФайлу", ЭтотОбъект, Новый Структура("ДиалогОткрытияФайла",ДиалогОткрытияФайла)));
КонецПроцедуры

 &НаКлиенте
Процедура ПутьКФайлу(ВыбранныеФайлы, ДополнительныеПараметры) Экспорт   //Процедура обрабатывает результат выбора файла пользователем
    ДиалогОткрытияФайла = ДополнительныеПараметры.ДиалогОткрытияФайла;
    Если ВыбранныеФайлы <> Неопределено Тогда
        Объект.ПутьКФайлу = ДиалогОткрытияФайла.ПолноеИмяФайла;
    Иначе
        ПоказатьПредупреждение(Неопределено,"Файл не выбран!");
    КонецЕсли;
КонецПроцедуры  


&НаКлиенте
Процедура Загрузить(Команда)
    Если Объект.ПутьКФайлу = "" Тогда
        Сообщ = Новый СообщениеПользователю;
        Сообщ.Текст = "Выберите файл!";
        Сообщ.Сообщить();
    Иначе
        Эксель = Новый COMОбъект("Excel.Application");
        КнигаЭксель = Эксель.Workbooks.Open(Объект.ПутьКФайлу);
        Лист1 = Книгаэксель.WorkSheets(1);
        п = 2;    
        Пока п < 13 Цикл
            СтруктураДанных = Новый Структура;
            СтруктураДанных.Вставить("Артикул", СокрЛП(Лист1.Cells(п,1).value));      
            СтруктураДанных.Вставить("Наименование",СокрЛП(Лист1.Cells(п,2).value));
            СтруктураДанных.Вставить("Количество",СокрЛП(Лист1.Cells(п,3).value)); 
            СтруктураДанных.Вставить("ЕдиницаИзмерения",СокрЛП(Лист1.Cells(п,4).value));
            СтруктураДанных.Вставить("Тип",СокрЛП(Лист1.Cells(п,5).value));
            СтруктураДанных.Вставить("Цена",СокрЛП(Лист1.Cells(п,6).value));
            СтруктураДанных.Вставить("ГОСТ",СокрЛП(Лист1.Cells(п,7).value));
            
            ЗагрузкаНаСервере(СтруктураДанных);
            п = п+1;
        КонецЦикла;
        Сообщ = Новый СообщениеПользователю;
        Сообщ.Текст = "Данные были успешно загружены!"; 
        Сообщ.Сообщить();
        Эксель.Application.Quit();
    КонецЕсли;    
КонецПроцедуры


&НаСервере
Процедура ЗагрузкаНаСервере(СтруктураДанных)
        
    Если Справочники.ЕдиницыИзмерения.НайтиПоНаименованию(СтруктураДанных.ЕдиницаИзмерения) = Справочники.ЕдиницыИзмерения.ПустаяСсылка() Тогда
        ДобЕдиницы = Справочники.ЕдиницыИзмерения.СоздатьЭлемент();
        ДобЕдиницы.Наименование = СтруктураДанных.ЕдиницаИзмерения;   
        ДобЕдиницы.Записать();
    КонецЕсли;  
    
    Если Справочники.ТипыДеталей.НайтиПоНаименованию(СтруктураДанных.Тип) = Справочники.ТипыДеталей.ПустаяСсылка() Тогда
        ДобТипаД = Справочники.ТипыДеталей.СоздатьЭлемент();
        ДобТипаД.Наименование = СтруктураДанных.Тип;
        ДобТипаД.Записать();
    КонецЕсли;
        
    Если Справочники.ГОСТы.НайтиПоНаименованию(СтруктураДанных.ГОСТ) = Справочники.ГОСТы.ПустаяСсылка() Тогда
        ДобГост = Справочники.ГОСТы.СоздатьЭлемент();
        ДобГост.Наименование = СтруктураДанных.ГОСТ;
        ДобГост.Записать();
    КонецЕсли; 
    
    
        //детали и все все

    Если Справочники.Детали.НайтиПоНаименованию(СтруктураДанных.Наименование) = Справочники.Детали.ПустаяСсылка() Тогда
        ДобДетали = Справочники.Детали.СоздатьЭлемент();  
        ДобДетали.Артикул = СтруктураДанных.Артикул;
        ДобДетали.Наименование = СтруктураДанных.Наименование; 
        ДобДетали.Количество = СтруктураДанных.Количество;
        ДобДетали.ЕдиницаИзмерения = Справочники.ЕдиницыИзмерения.НайтиПоНаименованию(СтруктураДанных.ЕдиницаИзмерения);
        ДобДетали.Тип = Справочники.ТипыДеталей.НайтиПоНаименованию(СтруктураДанных.Тип);
        ДобДетали.Цена = СтруктураДанных.Цена;
        ДобДетали.ГОСТ = Справочники.ГОСТы.НайтиПоНаименованию(СтруктураДанных.ГОСТ);
        ДобДетали.Записать();
    КонецЕсли; 
КонецПроцедуры // ЗагрузкаНаСервере()

 

загрузка иксель загрузка

См. также

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

Реальный помощник, с помощью которого Вы преобразуете необходимые документы для Wildberries, OZON, ЯндексМаркет, Мегамаркет, Aliexpress, Детский мир, МагнитЭкспресс (быв.Казань-Экспресс), Леруа Мерлен, ЭНФАНТА (Акушерство), ЛаМода, Летуаль, Твой дом, Золотое Яблоко в документы "Отчет комиссионера (агента) о продажах" и другие. Работает в 1С:БП 3.0, 1С:БП 3.0 КОРП, 1С:УТ 11, 1С:УНФ, 1С:КА 2, 1С:ERP Управление предприятием. Возможность подключить любые маркетплейсы. Анализ продаж ОZON. 30 дней БЕСПЛАТНОГО пользования!

5400 руб.

12.08.2021    38128    408    68    

174

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

Обработки загрузки данных о продажах WildBerries предназначены для следующих конфигураций: Бухгалтерия предприятия, редакция 3.0; Управление нашей фирмой, редакция 3.0; Розница, редакция 3.0; Управление торговлей, редакция 11; Управление торговлей, редакция 10.3

4800 руб.

11.12.2019    59525    1017    3    

255

SALE! 30%

ЭДО и ОФД Загрузка и выгрузка в Excel Бухгалтер Бухгалтерский учет 1С:Управление торговлей 10 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Бухгалтерский учет Платные (руб)

Кто получает документы в формате XML из различных сервисов ЭДО (формат 820 приказ ФНС 31 мая 2019) и набивает их вручную в 1С, тот наверняка хотел бы автоматизировать этот процесс. Поддержка конфигураций: Бухгалтерии 3, УПП 1.3, 1С:КА 2.4 и 1С:КА 2.5, УТ10, УТ11.4 и УТ11.5. Для бухгалтерии 3 добавлена поддержка формат 5.03 от 23/01/2025

3600 руб.

11.02.2020    94901    320    157    

232

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

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

4800 руб.

24.01.2021    21358    86    0    

36

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

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

4800 руб.

23.01.2022    11767    65    0    

41

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

Загрузка данных отчета о реализации и продаже товаров из сервиса Яндекс.Маркета «Беру» из отчетов Excel для конфигурации: Бухгалтерия предприятия, редакция 3.0; Управление торговлей, редакция 11; Управление торговлей, редакция 10.3; Управление нашей фирмой, редакция 3.0 и Розница, редакция 3.0 в документ «Отчет комиссионера о продажах».

4800 руб.

09.12.2020    26682    260    1    

123
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. kai068 5 06.04.23 12:06 Сейчас в теме
А если у кого нет Excel? Установлен LibreOffice какой-нибудь.
Я пользуюсь универсальной загрузкой из любого табличного документа.

ТабличныйДок = Новый ТабличныйДокумент();
	ТабличныйДок.Прочитать(ФайлЗагрузки);
	
	Для Каждого Область Из ТабличныйДок.Области Цикл
		
		ЧитаемаяОбласть = ТабличныйДок.ПолучитьОбласть(Область.Имя);
			
			ПостроительЗапроса = Новый ПостроительЗапроса;
			ИсточникДанных = ЧитаемаяОбласть.Область(1, 1, ЧитаемаяОбласть.ВысотаТаблицы, ЧитаемаяОбласть.ШиринаТаблицы);
			ПостроительЗапроса.ИсточникДанных = Новый ОписаниеИсточникаДанных(ИсточникДанных );
			ПостроительЗапроса.ДобавлениеПредставлений = ТипДобавленияПредставлений.НеДобавлять;
			ПостроительЗапроса.ЗаполнитьНастройки();
			ПостроительЗапроса.Выполнить();
			ТаблицаДанных = ПостроительЗапроса.Результат.Выгрузить();
	КонецЦикла;
Показать


И все данные в ТЗ ТаблицаДанных. Очень удобно.
chernoff; additive; +2 Ответить
2. mcgoblin 3 08.04.23 18:38 Сейчас в теме
Вызов сервера в цикле?!!! да еще с передачей всего контекста о.О
3. paramedic 10.04.23 09:41 Сейчас в теме
Повеяло самым началом 00-х. 1С нормально не работает ни под чем кроме Windows, ТабличныйДокумент не читает ничего кроме mxl.
А если нет Excel? А если в таблице больше 11 строк?
Как ученический код взаимодействия с com-объектом Excel еще пойдет, но в практической работе такое использовать нельзя.
nagieva.d; Danila-Master; +2 Ответить
Оставьте свое сообщение