Форум программистов, компьютерный форум, киберфорум
Java: GUI, графика
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 16.05.2012
Сообщений: 15

ArrayList и JTable

04.04.2013, 20:53. Показов 1601. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Пишу программу для анализа данных, в частности, расчета матрицы корреляции.
Данные вытаскиваю из excel-файла в двумерный ArrayList. Требуется отобразить таблицу, взятую из excel, в JTable.
Из-за неизвестного заранее размера таблицы не могу правильно описать модель. Помогите, пожалуйста!

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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
private void openMenuItemActionPerformed(ActionEvent e)
    {
        try
        {
            JFileChooser chooser = new JFileChooser();
            FileNameExtensionFilter filter = new FileNameExtensionFilter("Microsoft Excel Document","xlsx","xls");
            chooser.setFileFilter(filter);
            int returnVal = chooser.showOpenDialog(this);
            if(returnVal == JFileChooser.APPROVE_OPTION)
            {
                File path = chooser.getSelectedFile();
                FileInputStream inputStream = new FileInputStream(path);
                XSSFWorkbook workbook = new XSSFWorkbook(inputStream);
                XSSFSheet sheet = workbook.getSheetAt(0);
                Iterator rows = sheet.rowIterator();
                while(rows.hasNext())
                {
                    XSSFRow row = (XSSFRow) rows.next();
                    Iterator cells = row.cellIterator();
 
                    ArrayList data = new ArrayList();
                    while (cells.hasNext())
                    {
                        XSSFCell cell = (XSSFCell) cells.next();
                        data.add(cell);
                    }
 
                    correlation.sheetData.add(data);
                }
            }
            tableModel model = new tableModel();
            dataTable.setModel(model);
        }
        catch (UnsupportedEncodingException e1)
        {
            e1.printStackTrace();  //To change body of catch statement use File | Settings | File Templates.
        }
        catch (IOException e1)
        {
            e1.printStackTrace();  //To change body of catch statement use File | Settings | File Templates.
        }
    }
 
    public class tableModel extends AbstractTableModel
    {
        final String colHeaders [] = new String[correlation.sheetData.get(0).size()];
 
        @Override
        public int getColumnCount()
        {
            return colHeaders.length;
        }
 
        public int getRowCount()
        {
            return correlation.sheetData.size();
        }
 
        public Object getValueAt(int rowIndex, int columnIndex)
        {
            String value = null;
            return value = correlation.sheetData.get(rowIndex).get(columnIndex);
        }
 
        public String getColumnName(int column)
        {
            return colHeaders[column];
        }
 
        public boolean isCellEditable(int row, int col)
        {
            return false;
        }
    }
Собственно, сама инициализация коллекции:
Java
1
public List<List<String>> sheetData = new ArrayList();
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.04.2013, 20:53
Ответы с готовыми решениями:

JTable and ArrayList
Всем Доброе время суток Условие такое, считать всю информацию с txt файла и вставить в таблицу. txt такой: ...

Как данные с ArrayList поместить в JTable?
Всем привет! Есть 4 ArrayLista T, La, Lo, A. Как данные из этих листов поместить в JTable, чтобы каждый лист был в отдельной колонке? ...

Выделенные ряды jTable добавить в ArrayList
Доброго времени суток! Задача такая: есть таблица, в которой хранятся объекты класса, мне надо выделить несколько рядов таблицы с этими...

2
 Аватар для mutagen
2587 / 2260 / 257
Регистрация: 14.09.2011
Сообщений: 5,185
Записей в блоге: 18
05.04.2013, 00:04
ну наполните листы данными а потом преобразуйте в 2мерный массив и пользуйтесь стандартной моделью
0
0 / 0 / 0
Регистрация: 16.05.2012
Сообщений: 15
06.04.2013, 15:09  [ТС]
я, честно говоря, не могу понять как организовать метод "getValueAT". Раньше делал через switch-case, но я знал кол-во столбцов, соответственно и кол-во case'ов. А тут не знаю как это сделать.

Добавлено через 38 минут
так, проблему я понял. она состоит в том, что выбирая один элемент ArrayList'a вот таким способом: sheetData.get(0).get(4), я получаю не [0][4] элемент, а [0][0] + [0][1] + [0][2] + [0][3] + [0][4].
То есть, вместо:

Население - размер рынка (млн. чел)

я получаю:

[Страна, ВВП на душу населения (дол. на душу), Доля промышленности в ВВП (%% к ВВП), Сравнительная стоимость жизни (инд. без жилья) (%% к Нью-Йорку), Население - размер рынка (млн. чел)]

С чем это связано я понять не могу.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.04.2013, 15:09
Помогаю со студенческими работами здесь

Поиск в ArrayList и запись результата в JTable
в общем есть код на поиск в массиве ArrayList arr: private void jButton4ActionPerformed(java.awt.event.ActionEvent evt) { ...

Как реализовать JTable в которым данные берутся из ArrayList?
Всем привет. Я знаю как сделать обычный JTable в который данные добавляются только один раз при компилировании. Как реализовать JTable в...

Обращение к элементам ArrayList, который в другом ArrayList
Здравствуйте. У меня есть arraylist типа arraylist. А уже каждый внутренний arraylist типа JTextField. У JTextField (текстовое поле)...

JTable: как сделать, чтобы пользователь мог выбирать только строку целиком, и не мог изменять любую ячейку
Приветствую вас форумчане, вопрос такой Как сделать такую фичу: У меня есть JTable в котором 4 колонки, и n- строк, надо сделать так,...

Как задать размеры столбцов и стиль названий столбцов в JTable?
Пишу программу и зашел в тупик. Как задать размеры столбцов в JTable и как задать стиль названий столбцов в JTable? Спасибо.


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru