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

21.10.14

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

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

Файлы

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

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

Подписка 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! 30%

Загрузка и выгрузка в 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 7200 руб.

09.11.2016    271991    1202    957    

1113

Загрузка и выгрузка в 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    231019    742    532    

494

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

20740 руб.

20.11.2015    173354    426    396    

542

Загрузка и выгрузка в 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    24556    119    0    

61

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

Расширение освободит вас от необходимости вручную обновлять информацию о товарах в группах ВКонтакте. Достаточно задать правила один раз, и система автоматически формирует файлы yml для дальнейшей загрузки в группы в ВК. Вы сможете легко выбирать, какие товары публиковать, создавая гибкие критерии отбора. Например, можно добавить важные для покупателей параметры: цвет, размер или другие характеристики.

12200 руб.

29.08.2025    2446    6    6    

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

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