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

21.10.14

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

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

Файлы

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

Наименование Скачано Купить файл
Работа с файлом excel
.epf 7,59Kb
6 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

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

Загрузим вот такой файл 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С:Предприятие 8 1С:Бухгалтерия 2.0 1С:Бухгалтерия 3.0 1С:Управление производственным предприятием 1С:ERP Управление предприятием 2 1С:Управление холдингом 1С:Комплексная автоматизация 1.х 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 1.6 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 10 1С:Управление торговлей 11 1С:Розница 2 1С:Розница 3.0 Бухгалтерский учет Управленческий учет Платные (руб)

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

8000 руб.

09.11.2016    262974    1161    940    

1088

Загрузка и выгрузка в Excel Маркетплейсы Программист Бухгалтер Пользователь 1С:Предприятие 8 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С:ERP Управление предприятием.

5400 руб.

12.08.2021    43038    504    71    

202

Загрузка и выгрузка в 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. Задействованы все возможности конфигурации - заполнение реквизитов номенклатуры, дополнительных реквизитов и сведений, характеристики, доп.реквизиты и сведения характеристик. Дополнительные обработки для расширения возможностей.

12240 руб.

29.10.2014    226954    712    528    

481

Загрузка и выгрузка в 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 форматов без офиса, на любом сервере! Визуальное связывание колонок файла и реквизитов простым перетаскиванием колонок. Создание или обновление номенклатуры с иерархией, характеристик, доп. реквизитов, упаковок, загрузка практически неограниченного количества картинок на одну номенклатуру (с возможностью загрузки в несколько потоков одновременно), с хранением в томах или в базе. Загрузка номенклатуры поставщиков или поиск по их данным номенклатуры. Загрузка доп. реквизитов в характеристики. Загрузка штрихкодов с генерацией новых. Создание элементов справочников и ПВХ "на лету" для выбранных реквизитов. (Обновление от 17.11.2025, версия 9.13 - 10.5)

19200 руб.

20.11.2015    169262    421    389    

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

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