Чтение книги Exсel по листам

23.11.22

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

Речь пойдет о чтении xls файлов штатными средствами 1С постранично, возможно, для Вас это не будет новым способом, но может послужить как стимулом копаться в коде, так и быстрым решением проблемы загрузки для кого-то.

При поиске загрузки Exel файлов в 1С самым распространенным бывает способ через компоненту, которая требует установленного microsoft office.

Хорошо, найдём другой способ, благо платформа не стоит на месте и прекрасно нам помогает в решении наших задач.

Итак, имеем:

1) exсel файл

2) считываем его в табличный документ

3) берём построитель запроса

4) источник данных наш табличный документ

5) считываем в ТЗ

Я всегда думал (и никогда не пробовал иначе), что при чтении exсel в табличный документ считывается только первый лист.

Но, оказывается, нет:

ТабличныйДокумент.Области - тут будут все наши листы

Перейдём к коду:

1. Считываем в табличный документ
 

ТабличныйДок = Новый ТабличныйДокумент();
ТабличныйДок.Прочитать(ИмяВременногоФайла);

2. Обходим области и считываем содержимое в таблицу значений

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


Возможные проблемы могут быть с большими эксель файлами, не делал прям специально каких то огромных файлов и их чтение, пока какие попадались для загрузки, прекрасно поддавались данному методу.

чтение xls фалов

См. также

SALE! 10%

Загрузка номенклатуры из Excel в УТ11, КА 2, ERP 2, Розница 2. Дополнительные реквизиты и сведения, характеристики, картинки, цены, остатки

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

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

10560 9504 руб.

29.10.2014    210169    620    524    

439

Загрузка номенклатуры c картинками (несколько потоков одновременно) и сопутствующими данными в базу и любые документы из yml, xls, xlsx, xlsm, ods, ots, csv для УТ 10.3, УТ 11 (все), БП 3, КА 2, ERP 2, УНФ 1.6/3.0, Розница 2

Загрузка и выгрузка в 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 Платные (руб)

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

13200 руб.

20.11.2015    150717    367    375    

501

Маркетплейсный загрузчик для 12-ти маркетплейсов в "БП 3", "УТ 11", "КА 2", ERP, УНФ

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

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

1800 руб.

12.08.2021    31893    226    63    

117

SALE! 20%

Загрузка документов и номенклатуры из Excel в 1С "одним нажатием": УПД, ТОРГ-12, отчеты маркетплейсов, заказы, счета, прайсы

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

Универсальная обработка для загрузки документов из Excel в 1С. Не требует указания параметров (номера колонок, номер первой строки таблицы и т.д.) и предварительной настройки. Просто выбираете файл Excel, документ 1С и нажимаете кнопку "Загрузить". Обработка сама находит таблицу в файле Excel, необходимые для загрузки данные в ней (номенклатура, количество, НДС, цена, сумма) и загружает ее в 1С. Вместе с номенклатурой может найти контрагента, номер и дату документа, штрих-коды, серии ГТД, страну и т.д. Распознает документы ЛЮБОЙ ФОРМЫ (УПД, ТОРГ-12, заказ, отчет комиссионера и т.д.). Не требует MS Office. Для поиска таблиц используются методы эвристического поиска. Загружает только то, что нужно, т.е. пропускает повторы шапки таблицы, заголовки, промежуточные итоги, подписи и т.д. Содержит модуль работы с электронной почтой и api-загрузчик отчетов о продажах маркетплейсов.

5000 4000 руб.

09.11.2016    214924    925    886    

939

Загрузка данных отчета о реализации товаров из Excel файла СберМегаМаркет

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

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

4800 руб.

07.06.2022    15077    79    0    

60

SALE! 30%

Распознавание и загрузка сканов в 1С "одним нажатием": УПД, ТОРГ-12, накладные, счета, номенклатура, заказы и т.д.

Загрузка и выгрузка в Excel Документооборот и делопроизводство (СЭД) Учет документов Распознавание документов и образов Управляемые формы 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С. Не требует указания параметров и предварительной настройки. Просто выбираете файл (PDF, JPG, DOC, XLS, HTML и т.д.) выбираете документ 1С и нажимаете кнопку "Распознать и загрузить".

6000 5520 руб.

04.06.2019    101374    296    173    

312
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. svezr 5 30.11.22 12:30 Сейчас в теме
Проще всего читать постранично через популярный метод табличного документа Прочитать().

Если читаемый XLSX многостраничный, то каждая страница помещается в отдельную область, доступ к которой возможен через реквизит ТабличногоДокумента "Области" - коллекцию областей.

Чтобы получить количество строк листа можно использовать свойство области "Низ".

Например, абстрактно можно это написать как

	ТабличныйДокумент.Прочитать(ИмяВременногофайла, СпособЧтенияЗначенийТабличногоДокумента.Значение);

	КоличествоЛистовДокумента = ТабличныйДокумент.Области.Количество();
	
	Если КоличествоЛистовДокумента <= 1 Тогда
		ИтогоСтрок = ТабличныйДокумент.ВысотаТаблицы;
	Иначе
		ИтогоСтрок = ТабличныйДокумент.Области[0].Низ;
	КонецЕсли;
Показать
_Vovik; skillhoster; TerveRus; +3 Ответить
3. ix5s 118 02.12.22 00:02 Сейчас в теме
(1) Да, именно тот же способ что описан в статье
ТабличныйДок.Прочитать(ИмяВременногоФайла);
потом обходим области и каждую читаем в таблицу значений
единственное можно сократить код
в ПЗ.ИсточникДанных = Новый ОписаниеИсточникаДанных(ТабличныйДок.Область.Верх + Смещение, НомерПервойКолонки, ТабличныйДок.Область.Низ, Область.Ширина)

Но тут как раз речь про области, я к своему удивлению думал всегда что читается только первый лист

(1)
Скрыть
2. pyrkin_vanya 488 01.12.22 20:24 Сейчас в теме
4. ix5s 118 02.12.22 00:03 Сейчас в теме
(2)не совсем понятно как, так как кода то нет, только качать обработку и разбираться что внутри
так же не понял у вас на скринах первой стройкой итоги идут после шапки, а в таблице этой строки нет почему то
5. pyrkin_vanya 488 02.12.22 08:40 Сейчас в теме
(4)Моя обработка читает любой файл ексель с определенной строки и динамически выводит это на экран.
6. ix5s 118 02.12.22 13:16 Сейчас в теме
(5)
Моя обработка читает любой файл ексель с определенной строки и динамически выводит это на экран

как обработка прочитает файл с 5 листами, где на 3 листе шапка в 5 строке, а во всех остальных в 2 строке?
и сколько на выходе будет таблиц?
еще интересно, если указать что шапка в строке 2 а читать с 10 строки, как поведет себя загрузчик?
7. skillhoster 20.06.23 09:17 Сейчас в теме
Действительно ПолучитьОбласть().Область() кажется излишним, можно сразу использовать итерируемую "Область", либо ТабличныйДок.Области[Сч]
За пример - спасибо.
8. almazx4 2 30.07.23 15:38 Сейчас в теме
также пользуюсь таким способом чтения Excel, способ хорош тем, что работает значительно быстрее, чем обычный через Cells(), но у меня он не хочет читать большие файлы Excel, в которых свыше 100 тыс. строк. Пока не нашел решения что с этим сделать. Иногда возникает необходимость загрузить файлы, прайс например или таблицу с товарами, в которых бывает по полмиллиона строк, приходится делить файл на части. Если кто-то знает решение, поделитесь пож-та.
12. ix5s 118 23.01.24 15:53 Сейчас в теме
(11)
(8)
Если кто-то знает решение, поделитесь пож-та


А пробовали читать по ячейкам?
не конвертировать в ТЗ через построитель, а обходить прям по ячейкам?
9. ix5s 118 31.07.23 17:36 Сейчас в теме
(8) попробую поэксперементировать, чисто теоретически возможно можно бить на блоки и читать порциями, у мен обычно файлы до 100к.
10. VZhulanov 4 04.12.23 20:51 Сейчас в теме
тоже всегда этим способом пользовался для импорта ежедневного, а тут обнаружил что с 1го декабря справочник перестал обновляться
проверяю - вместо обычного xls формата стали выкладывать сжатый xlsx, который в 10 раз меньше места занимает
Экселем то файл без проблем читается, а 1Ску тупо вылетает с неожиданным завершением и все

если кто хочет протестировать то могу файл скинуть, он 8 мегов теперь всего занимает
либо его можно скачать с официального сайта Минздрава
https://grls.rosminzdrav.ru/LimPriceArchive.aspx
11. VZhulanov 4 05.12.23 07:13 Сейчас в теме
(10) если считывать файл через COM объект Excel.Application то он читается, но очень уж медленно
прежний файл считывается в ТабличныйДокумент за 6 секунд - можно скачать по ссылке выше за любую дату раньше 01.12.2023
новый же файл через Excel.Application у меня считывался 1200 секунд

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