Вход | Регистрация

1С:Предприятие :: 1С:Предприятие 8 общая

8.2 Чтение из xls в табличный документ. Страницы

8.2 Чтение из xls в табличный документ. Страницы
Я
   1dvd
 
26.09.17 - 14:36
Делаю чтение xls файла в табличный документ и напоролся на проблему

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


Он считывает одновременно со всех листов. Как указать конкретный лист?
 
 
   Cyberhawk
 
1 - 26.09.17 - 14:37
В случае xls штатно никак. В случае с xlsx легко.
   1dvd
 
2 - 26.09.17 - 14:37
(1) ок. Как в случае xlsx?
   Cyberhawk
 
3 - 26.09.17 - 14:42
(2) Читать методом, за которым закрепилось название "Native XLSX". Распаковываешь xlsx-файл как зип-архив в папку, далее через ЧтениеХМЛ (или ПостроительДОМ) работаешь с хмл-файликом
"XL\WorkSheets\Sheet" + ФайлНомерЛиста + ".xml"
   Cyberhawk
 
4 - 26.09.17 - 14:42
Пример, например, тут: http://catalog.mista.ru/public/225624/
   1dvd
 
5 - 26.09.17 - 14:42
пелять... это это легко
   1dvd
 
6 - 26.09.17 - 14:43
кривая одинеска
   Cyberhawk
 
7 - 26.09.17 - 14:44
(5) Просто в одних листах могут быть ссылки на ячейки с других листов.
Если такого нет, то можно методом из (3) удалить ненужные листы и запаковать файл обратно и потом уже читать через ТабДок :)
   1dvd
 
8 - 26.09.17 - 14:51
похрен. скажу чтобы подсовывали однолистный файл

Список тем форума
Рекламное место пустует  Рекламное место пустует
ВНИМАНИЕ! Если вы потеряли окно ввода сообщения, нажмите Ctrl-F5 или Ctrl-R или кнопку "Обновить" в браузере.
Тема не обновлялась длительное время, и была помечена как архивная. Добавление сообщений невозможно.
Но вы можете создать новую ветку и вам обязательно ответят!
Каждый час на Волшебном форуме бывает более 2000 человек.
Рекламное место пустует