0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 16

Копирование стиля ячеек excel с использованием apach poi

29.09.2014, 17:08. Показов 9458. Ответов 22
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток! Очень нужна помощь.
Есть следующий метод. Все работало хорошо, пока данных не оказалось очень много. Теперь он выдает

Java
1
Exception in thread "AWT-EventQueue-0" java.lang.IllegalStateException: The maximum number of cell styles was exceeded. You can define up to 4000 styles in a .xls workbook
Вынести за цикл не получается. Подскажите,что еще можно сделать и как переделать метод?

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/**
     * Установить обработанное значение ячейке
     * @param curRow   обрабатываемая ячейка
     * @param templStyleRow ячейка со стилями
     * @param templValueRow ячейка с шаблонной строкой
     * @param colCount количество обрабатываемых ячеек 
     */
    private void setParsedValuesToRow(HSSFWorkbook workBook, HSSFSheet sheet,int curRowInd,Row templStyleRow, Row templValueRow,int colCount){
    //private void setParsedValuesToRow(HSSFSheet sheet,int curRowInd,Row templStyleRow, Row templValueRow,int colCount){
        //создаем строку в листе
            
        sheet.createRow(curRowInd);
        
        //обрабатываемая строка таблицы
        Row curRow = sheet.getRow(curRowInd);
    //  System.out.println("colCount="+colCount);
        //создаем ячейки строки 
        for(int j=0;j<colCount;j++)
            curRow.createCell(j);
        
        //из листа стиля устанавливаем высоту строки
        curRow.setHeightInPoints(templStyleRow.getHeightInPoints());
        
        //копирование стилей ячеек и обработка значений из шаблонной строки
        for(int i=0;i< colCount;i++){
    
            //копируем в ячейку пропарсенное из шаблона значение
            if((curRow.getCell(i) != null)&&(templStyleRow.getCell(i) != null)&&(templValueRow.getCell(i) != null))
                setParsedValueToCell(curRow.getCell(i), templStyleRow.getCell(i),templValueRow.getCell(i));
            System.out.println("i="+i);
            //КЛОНИРУЕМ в ячейку соответствующий стиль
    
            if((templStyleRow.getCell(i) != null)&&(curRow.getCell(i) != null)){
                //создаем стиль
                CellStyle cloneStyle; 
                cloneStyle = workBook.createCellStyle();// ошибка выдается тут
            
                //клонируем в книгу стиль
                cloneStyle.cloneStyleFrom(templStyleRow.getCell(i).getCellStyle());
                
                //присваиваем стиль уже из родной книги
                curRow.getCell(i).setCellStyle(cloneStyle);
            }
            
        }
    }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.09.2014, 17:08
Ответы с готовыми решениями:

Apache POI, диапазон ячеек
Как покрасить диапазон ячеек?

Apach POI работа с Drawing
Мне необходимо открыть Excel-файл с комментариями и добавить комментарий в несколько ячеек. Проблема в том, что иногда способа создать...

Apache POI Exel копирование строки
Всем привет. Пишу программку, смысл такой: Есть файл .xls, в котором 2 страницы, одна заполнена таблицей, вторая пустая. Нужно в...

22
0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 16
03.10.2014, 11:44  [ТС]
Студворк — интернет-сервис помощи студентам
turbanoff, спасибо за совет, но слишком много методов написано для работы с шаблонами, не думаю,что все их переделать будет проще. Заменить то шаблоны не проблема. Но ведь надо и методы править. У меня только по работе с вордом 27 методов реализовано, а есть же еще в др классах
0
185 / 160 / 49
Регистрация: 30.07.2013
Сообщений: 508
03.10.2014, 11:59
Писать надо было на интерфейсах, а не на реализациях. У HSSFWorkbook и SXSSFWorkbook общий интерфейс Workbook. И тогда в твоем большом методе можно было формировать и xls и xlsx.
0
0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 16
03.10.2014, 12:02  [ТС]
Писала не я,и что уж тут говорить как надо было. Хотя я думаю даже в данной ситуации должно быть решение, главное хорошенько поискать...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.10.2014, 12:02
Помогаю со студенческими работами здесь

Переделать программу с использованием poi
Здравствуйте, помогите пожалуйста переделать программу под библиотеку poi. Программа должна брать данные из exel и рассчитывать...

Копирование ячеек Excel
Доброго дня, столкнулся с проблемой, не могу понять почему выпадает исключение, собственно есть код, который открывает 2 Excel файла и из...

Копирование диапазона ячеек из Excel в Word
Приветствую. Уважаемые, столкнулся с проблемой копированя диапазона ячеек из Excel в Word. Имеется лист Экселя который...

Копирование ячеек из книги excel в таблицу access
Здравствуйте. Подскажите, пожалуйста, как с помощью vba скопировать ячейки из книги excel в таблицу access. и можно ли подключить...

Копирование листа excel с сохранением формата ячеек
Добрый день! Копирую лист с одного excel файла в другой вот таким способом: vTemp=wSheet1.OlePropertyGet(&quot;Range&quot;,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
23
Ответ Создать тему
Опции темы

Новые блоги и статьи
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru