Почему не получается использовать ТабличныйДокумент для работы с Excel?

01.12.23

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

Трудности загрузки/выгрузки эксельных прайсов.

Одним из полезных нововведений на платформе 8.3.6 стала возможность возможность импорта содержимого из файлов в форматах XLS (Microsoft Excel 97), Microsoft Office OpenXML (Microsoft Excel 2007- 2010) и ODS (OpenDocument) в табличный документ.
На платформе 8.3.10 появилась возможность считывания данных с отдельных листов книги EXCEL.
Данная возможность доступна как в интерактивном режиме, так и из встроенного языка.
Реализована поддержка вставки из буфера обмена областей, скопированных из Microsoft Excel и OpenOffice Calc.
Реализация импорта из EXCEL на встроенном языке стала возможна в результате нововведений в функционал объекта "ТабличныйДокумент":
Для метода "Прочитать" объекта "ТабличныйДокумент" реализован параметр "СпособЧтенияЗначений" (Новое системное перечисление "СпособЧтенияЗначенийТабличногоДокумента"). (с) Загрузка из EXCEL


<СпособЧтенияЗначений> (необязательный)

Тип: СпособЧтенияЗначенийТабличногоДокумента.
Определяет, каким образом нужно интерпретировать значения, считываемые из исходного документа XLS, XLSX или ODS.
При загрузке табличного документа из формата Excel 97 - 2010 и OpenOffice Calc, в случае если в ячейке исходного документа содержалось значение типа Дата или Число, то в ячейку результирующего табличного документа это значение попадает в зависимости от значения этого параметра.
Значение по умолчанию: Текст.


Построитель = Новый ПостроительОтчета;
Построитель.ИсточникДанных = Новый ОписаниеИсточникаДанных(тз);
Построитель.Выполнить();
Построитель.Вывести();


Так вот. И в excel и в mxl ячейка может содержать значение и иметь формат представления. Проблема в том, что СКД при выводе значений в табличный документ выводит только представление... 

Проблема при сохранении табличного документа в файл xlsx

Если в ячейке будет код номенклатуры с лидирующими нулями - при экспорте в эксель значение ячейки их обрежет,
например было "00246100" стало "246100":

ТабДокумент = Новый ТабличныйДокумент;
ТабДокумент.Область(1,1).Текст = "Номенклатура";
ТабДокумент.Область(1,2).Текст = "Артикул";
ТабДокумент.Область(2,1).Текст = "NSIN0001130294";
ТабДокумент.Область(2,2).Текст = "00246100";
ИмяФайлаXLSX = ПолучитьИмяВременногоФайла("xlsx");
ТабДокумент.Записать(ИмяФайлаXLSX, ТипФайлаТабличногоДокумента.XLSX);
ЗапуститьПриложение(ИмяФайлаXLSX);

Выведет:

При этом в представлении всё верно...

И да, если переименовать xlsx в zip и открыть архиватором sheet1.xml - то там будет именно "246100".


Конечно, есть ещё вариант ручной установки значения ячейки таб. документа, и он работает.
На клиенте...

	#Если ТолстыйКлиентОбычноеПриложение Тогда
		// В экселе значение ячейки отличается от представления (обрезает лидирующие нули и т.п.)
		Область = ТабДок.Область(1,1,ТабДок.ВысотаТаблицы, ТабДок.ШиринаТаблицы);
		Область.Защита = Ложь;
		Область.СодержитЗначение = Истина;
	#КонецЕсли

Но #НаСервере установка свойства СодержитЗначение приводит к очистке. И в справке про это ничего нет...

Для регламентных не годится.

Проблема при загрузке табличного документа из файла xlsx

При загрузке файла экселя, сформированного в других языках программирования, содержимое может вообще не прочитаться (если верить гуглу при поиске заголовков этого файла выдаёт Open XML SDK 2.5),
например:

ИмяФайлаXLSX = ПолучитьИмяВременногоФайла("xlsx");
Ссылка = "https://raw.githubusercontent.com/kuzyara/ConvertCSV/master/priceberg.xlsx";
КопироватьФайл(Ссылка, ИмяФайлаXLSX);
//ЗапуститьПриложение(ИмяФайлаXLSX);
ТабДокумент = Новый ТабличныйДокумент;
ТабДокумент.Прочитать(ИмяФайлаXLSX, СпособЧтенияЗначенийТабличногоДокумента.Значение);
ЗаполненоЯчеек = 0;
Для НомерСтроки = 1 По ТабДокумент.ВысотаТаблицы Цикл
	Для НомерСтолбца = 1 По ТабДокумент.ШиринаТаблицы Цикл
		ТекЗначение = ТабДокумент.Область(НомерСтроки,НомерСтолбца).Текст;
		Если НЕ ПустаяСтрока(ТекЗначение) Тогда
			ЗаполненоЯчеек = ЗаполненоЯчеек + 1;
		КонецЕсли;
	КонецЦикла;
КонецЦикла;
Сообщить("Заполнено ячеек: " + ЗаполненоЯчеек);
// Выведет:
//
// Заполнено ячеек: 0

В режиме предприятия (меню Файл - Открыть) это пустой таб. документ
с 1026 столбца...

Хотя в экселе файл открывается прекрасно:

Нюансы (различия) чтения методом OLE и ТабДок

 

//COM
	Excel = Новый COMОбъект("Excel.Application");
	Excel.Visible=0;
	Excel.FileValidation = 1;
	Excel.Workbooks.Open(ИмяФайла, , Истина);
	Book 	= Excel.Workbooks(1);
	Sheet 	= Book.Sheets(1);
	МассивМассивовXLS = Sheet.UsedRange.Value.Выгрузить();
//ТАБ
	ТабДокумент= Новый ТабличныйДокумент;
	ТабДокумент.Прочитать(ИмяФайлаXLSX);
	ПостроительОтчета = Новый ПостроительОтчета; 
	ПостроительОтчета.ИсточникДанных = Новый ОписаниеИсточникаДанных(ТабДокумент.Область());
	ПостроительОтчета.Выполнить();
	// Результат выгружаем в таблицу значений.
	ТабЗначений = ПостроительОтчета.Результат.Выгрузить();

Часть кода для сравнения этих методов:

	ИначеЕсли СтрНайти(Стр, ",") > 0 Тогда
		//СтрокаCOM[КиЗ.Ключ]	"0,00002"	Строка
		//СтрокаТАБ[КиЗ.Значение]	"0,000020"	Строка
		// ...
		ДобавитьНюанс(Нюансы, "Нюанс1", СтрокаCOM[КиЗ.Ключ], СтрокаТАБ[КиЗ.Значение]);

	ИначеЕсли ТолькоЦифрыВСтроке(Стр) Тогда
		//СтрокаCOM[КиЗ.Ключ]	"58198119"	Строка
		//СтрокаТАБ[КиЗ.Значение]	"058198119"	Строка
		// ...
		ДобавитьНюанс(Нюансы, "Нюанс2", СтрокаCOM[КиЗ.Ключ], СтрокаТАБ[КиЗ.Значение]);

	ИначеЕсли КиЗ.Значение = "Колонка4" И СтрНайти(Стр, ".") > 0 Тогда
		//СтрокаCOM[КиЗ.Ключ]	"835,2"	Строка
		//СтрокаТАБ[КиЗ.Значение]	"835.2000000000001"	Строка
		// ...
		ДобавитьНюанс(Нюансы, "Нюанс3", СтрокаCOM[КиЗ.Ключ], СтрокаТАБ[КиЗ.Значение]);

	ИначеЕсли СодержимоеПервых100СтрокПусто(ТабДокумент) Тогда 
		// если платформа не смогла прочитать и выдала пустые строки
		// ...
		ДобавитьНюанс(Нюансы, "Нюанс4", "Пустые строки: NativeXLSX", "", Истина);

	ИначеЕсли СокрЛП(СтрокаОбразец[КиЗ.Ключ]) = СокрЛП(Стр) Тогда
		//СтрокаCOM[КиЗ.Ключ]	"уп.10"	Строка
		//СтрокаТАБ[КиЗ.Значение]	"уп.10                    "	Строка
		// ...
		ДобавитьНюанс(Нюансы, "Нюанс5", СтрокаCOM[КиЗ.Ключ], СтрокаТАБ[КиЗ.Значение]);

	ИначеЕсли ТабДокумент.ШиринаТаблицы > 1024 Тогда
		ДобавитьНюанс(Нюансы, "Нюанс6", "ШиринаТаблицы > 1024", "");

// и т.д.

Я конечно буду рад ошибаться, но, по-моему, нативные средства платформы по работе с Excel совсем далекоооооо не всегда применимы на практике.

См. также

SALE! 20%

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

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

6000 5100 руб.

09.11.2016    230001    988    894    

986

Загрузка и выгрузка в 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    215665    648    526    

455

Загрузка и выгрузка в 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 дней БЕСПЛАТНОГО пользования!

2400 руб.

12.08.2021    34658    318    66    

149

SALE! 30%

Загрузка и выгрузка в 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С и нажимаете кнопку "Распознать и загрузить".

8400 5880 руб.

04.06.2019    105311    307    173    

322

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

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

4800 руб.

09.12.2020    24646    242    1    

105

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

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

4800 руб.

07.06.2022    16862    106    0    

84
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Поручик 4690 21.06.19 22:33 Сейчас в теме
Вот это не работает. Запись в виде Excel в поток. А хотелось бы исключить лишние файловые операции.
		ТабДок = Новый ТабличныйДокумент;
		ОтчетОбъект.СкомпоноватьРезультат(ТабДок);
		
		Поток = Новый ПотокВПамяти;
		
		ТабДок.Записать(Поток, ТипФайлаТабличногоДокумента.XLSX);

Цель этой операции - тупо запихать сгенерированный отчет на FTP сервер в регламентном задании.
2. ltfriend 21.06.19 23:40 Сейчас в теме
(1) так об этом прямо сказано в синтаксис-помощнике. В поток только ods (или как там правильно, по памяти могу ошибиться) или mxl, поэтому от временных файлов полностью, увы, отказаться нельзя. Вот последний пример, по http запросу вернуть печ. форму документа в xlsx. Казалось бы, сохранил таю документ в поток в памяти, получил двоичные данные и передал клиенту. Но нет, приходиться прибегать к относительно медленным файловым операциям. Сохранить на диск в xlsx, потом считать с диска в память (двоичные данные) и только потом отдать клиенту.
rolin555; Поручик; +2 Ответить
3. wolfsoft 2421 24.06.19 08:36 Сейчас в теме
Да только тот факт, что табличный документ не читает многостраничные файлы, уже существенно снижает ценность чтения этим способом.
4. Shaldryn 05.08.20 12:47 Сейчас в теме
Спасибо за "СодержитЗначение", помогло в моей ситуации
5. METAL 299 17.11.21 15:46 Сейчас в теме
Извините, но правильно Нюанс
6. kuzyara 2072 01.12.23 07:48 Сейчас в теме
(5) спасибо, исправил
Оставьте свое сообщение