Кэширование файла Excel (без загрузки в базу данных).

21.10.14

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

Способ работы с большим файлом Excel, так же быстро, как с обычной таблицей (при помощи кэширования).

Скачать файл

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

Наименование По подписке [?] Купить один файл
Работа с файлом excel
.epf 7,59Kb
6
6 Скачать (1 SM) Купить за 1 850 руб.

При первом открытии обработки видим надпись Файл не загружен

Загрузим вот такой файл Excel  для примера

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

В дальнейшем при открытии обработки можно сразу жать кнопку Выполнить.

Сделал это с помощью выгрузки ТаблицыЗначений в файл и последующего использования этого файла.

По нажатию кнопки обновить:

Если Не ЗначениеЗаполнено(ПутьКФайлу) Тогда
		Сообщить("Выберите файл для загрузки!");	
		Возврат;
	КонецЕсли;	
	
	Док = ПолучитьCOMОбъект(ПутьКФайлу); 
	
	НомерЛиста = 1;
	ВсегоСтрок = Док.Sheets.Item(НомерЛиста).UsedRange.Rows.Count();
	
	КЧ = Новый КвалификаторыЧисла(10,0);
	КС = Новый КвалификаторыСтроки(200);
	Массив = Новый Массив;
	Массив.Добавить(Тип("Строка"));
	ОписаниеТиповС = Новый ОписаниеТипов(Массив, , КС);
	Массив.Очистить();
	Массив.Добавить(Тип("Число"));
	ОписаниеТиповЧ = Новый ОписаниеТипов(Массив, , ,КЧ);
	
	ТЗЕксель = Новый ТаблицаЗначений;
	ТЗЕксель.Колонки.Добавить("Наименование",ОписаниеТиповС);
	ТЗЕксель.Колонки.Добавить("Количество",ОписаниеТиповЧ);
		
	Для сч = 1 По ВсегоСтрок Цикл
        Наименование    =СокрЛП(Док.Sheets(НомерЛиста).Cells(сч, 1).Value);	
		Количество =СокрЛП(Док.Sheets(НомерЛиста).Cells(сч, 2).Value);
		НовСтр = ТЗЕксель.Добавить();
		НовСтр.Наименование = Наименование;
		НовСтр.Количество = Количество;
	КонецЦикла;
	
	УдалитьФайлы(ВремХранилище, "*.sel");
	ИмяФайла = СтрЗаменить(ТекущаяДата(),":",".");
	ЗначениеВФайл(ВремХранилище+ИмяФайла+".sel",ТЗЕксель);
	ЭлементыФормы.НадписьФайл.Заголовок = "Файл Excel последний раз обновлялся: " + ИмяФайла;

При открытии:

ВремХранилище = КаталогВременныхФайлов() + "excel\";
	Файл = Новый Файл(ВремХранилище);
	Если Не Файл.Существует() Тогда
		СоздатьКаталог(ВремХранилище);
	Иначе
		МассивНайденных = НайтиФайлы(ВремХранилище, "*.sel"); 

		Если МассивНайденных.Количество() > 0 Тогда
        	ЭлементыФормы.НадписьФайл.Заголовок = "Файл Excel последний раз обновлялся: " + МассивНайденных[0].ИмяБезРасширения;  
			ТЗЕксель = ЗначениеИзФайла(ВремХранилище + МассивНайденных[0].Имя);
		Иначе
			ЭлементыФормы.НадписьФайл.Заголовок = "Файл Excel не загружали!"; 
		КонецЕсли;		
	КонецЕсли;

По нажатию кнопки Выполнить:

Запрос = Новый Запрос;
	Запрос.Текст = "ВЫБРАТЬ
	               |	ТЗЕксель.Наименование,
	               |	ТЗЕксель.Количество
	               |ПОМЕСТИТЬ ВТ
	               |ИЗ
	               |	&ТЗЕксель КАК ТЗЕксель
	               |;
	               |
	               |////////////////////////////////////////////////////////////////////////////////
	               |ВЫБРАТЬ
	               |	ВТ.Наименование,
	               |	СУММА(ВТ.Количество) КАК Количество
	               |ИЗ
	               |	ВТ КАК ВТ
	               |
	               |СГРУППИРОВАТЬ ПО
	               |	ВТ.Наименование";
	Запрос.УстановитьПараметр("ТЗЕксель",ТЗЕксель);
	Выборка = Запрос.Выполнить().Выбрать();
	Пока Выборка.Следующий() Цикл
		Сообщить(Выборка.Наименование +" = "+ Выборка.Количество);	
	КонецЦикла;	


 



См. также

SALE! 15%

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

Универсальная обработка для загрузки документов из Excel в 1С. Забудьте о ручном вводе: загружайте документы из Excel в 1С за секунды! Не требует указания параметров (номера колонок, номер первой строки таблицы и т.д.) и предварительной настройки. Просто выбираете файл Excel, документ 1С и нажимаете кнопку "Загрузить". Обработка сама находит таблицу в файле Excel, необходимые для загрузки данные в ней (номенклатура, количество, НДС, цена, сумма) и загружает ее в 1С.

6000 5100 руб.

09.11.2016    243193    1124    911    

1050

Загрузка и выгрузка в 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    38292    414    68    

175

Загрузка и выгрузка в Excel Логистика, склад и ТМЦ Ценообразование, анализ цен Файловый обмен (TXT, XML, DBF), FTP Бухгалтер Пользователь Платформа 1С v8.3 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 форматов без офиса, на любом сервере! Визуальное связывание колонок файла и реквизитов простым перетаскиванием колонок. Создание или обновление номенклатуры с иерархией, характеристик, доп. реквизитов, упаковок, загрузка практически неограниченного количества картинок на одну номенклатуру (с возможностью загрузки в несколько потоков одновременно), с хранением в томах или в базе. Загрузка номенклатуры поставщиков или поиск по их данным номенклатуры. Загрузка доп. реквизитов в характеристики. Загрузка штрихкодов с генерацией новых. Создание элементов справочников и ПВХ "на лету" для выбранных реквизитов. (Обновление от 26.03.2025, версия 9.10 - 9.16)

18000 руб.

20.11.2015    159858    393    378    

522

Загрузка и выгрузка в 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    59654    1022    3    

257

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    95091    321    157    

232

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

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

11100 руб.

29.10.2014    218838    670    529    

459
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Yashazz 4836 30.09.14 19:34 Сейчас в теме
Тю... Я-то понадеялся на ADODB...
2. Gureev 01.10.14 10:42 Сейчас в теме
ерунда какая-то... ладно нет АДОДВ, так можно хотя бы область выгрузить! а не считывать поячеечно документ.
а если колонок 100, а строк 100тыщ ? этот алгоритм будет работать вечно.

ничего быстрого. заголовок не соответствует содержимому.
4. John_d 5987 01.10.14 10:53 Сейчас в теме
(2) Gureev, смысл не в том как загрузить ексель в ТаблицуЗначений.
А в том, что загрузить можно всего один раз. А дальше пользоваться уже сохраненной ТаблицейЗначений.
3. ander_ 01.10.14 10:45 Сейчас в теме
хм, "(без загрузки в базу данных)"...
а это что?

Для сч = 1 По ВсегоСтрок Цикл
        Наименование    =СокрЛП(Док.Sheets(НомерЛиста).Cells(сч, 1).Value);    
        Количество =СокрЛП(Док.Sheets(НомерЛиста).Cells(сч, 2).Value);
        НовСтр = ТЗЕксель.Добавить();
        НовСтр.Наименование = Наименование;
        НовСтр.Количество = Количество;
 КонецЦикла;


или надо понимать фразу как "мы же в справочники/документы/регистры не сохраняем" ? :)
5. DrAku1a 1757 01.10.14 14:41 Сейчас в теме
Если XLSX - то его можно безо всяких драйверов читать (на ИС есть примеры прямого чтения) - это ж набор XML, обжатых в ZIP.
А вообще, статью правильнее назвать например "Кэширование читаемых Excel-файлов"...
6. Yashazz 4836 01.10.14 14:47 Сейчас в теме
А как тут минуснуть можно?
7. mihast 68 21.10.14 07:55 Сейчас в теме
Нда... Кэширование входного файла... Это ж только при разработке/отладке один и тот же файл по 20 раз загружаешь... Да и там у меня, например, основные косяки с тем, что из Excel в 1С что-то не так загрузилось, а значит надо файл по новой загружать...
Короче - не могу даже придумать когда ЭТО реально может быть нужно...
8. John_d 5987 21.10.14 10:02 Сейчас в теме
(7) mihast, Например когда типовая конфа и она такой должна остаться. Нужно написать дополнительную обработку которая часть данных берет из Excel.
Оставьте свое сообщение