Форум программистов, компьютерный форум, киберфорум
Java
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
4 / 3 / 2
Регистрация: 11.06.2013
Сообщений: 298

Сравнение двух столбцов из разных файлов и запись результатов в третий файл ( Apache POI )

24.05.2019, 16:43. Показов 3281. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Не могу разобраться в цикле записи результатов сравнения двух столбцов(в обоих по 1 листу) в третью таблицу. Как правильно построить перестроить алгоритм(может я вообще неправильно записываю в ячейки). Нужно сравнить первый столбец первой таблицы, с первым столбцом второй таблицы. И если они совпадают - записать всю строку целиком из первой таблицы и вторую строку из второй таблицы в 3-ю таблицу. Заранее спасибо за любую помощь. Ниже предоставлю пример(отображается какое вышло):

таблица 1:
а | b | c | d |
3 t g g
2 r 2 a
1 е у ы

таблица 2:
а | b | c | d |
3 ы ц ф
4 r 2 a
1 е у ы

таблица 3:
а | b | c | d | e |
3 t g g ы
1 е у ы e

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
            HSSFWorkbook workbook1 = new HSSFWorkbook(file1);
            HSSFWorkbook workbook2 = new HSSFWorkbook(file2);
            HSSFWorkbook workbook3 = new HSSFWorkbook();
 
            HSSFSheet sheet1 = workbook1.getSheetAt(0);
            HSSFSheet sheet2 = workbook2.getSheetAt(0);
            HSSFSheet sheet3 = workbook3.createSheet("list1");
 
            Iterator<Row> rowIterator1 = sheet1.iterator();
            Iterator<Row> rowIterator2 = sheet2.iterator();
            Iterator<Row> rowIterator3 = sheet3.iterator();
 
            HSSFRow rowhead = sheet3.createRow((short)0);
            rowhead.createCell(0).setCellValue("Рег.");
            rowhead.createCell(1).setCellValue("Сокращённое название");
            rowhead.createCell(2).setCellValue("УНП");
            rowhead.createCell(3).setCellValue("Год");
            rowhead.createCell(4).setCellValue("Дата");
            rowhead.createCell(5).setCellValue("Квартал");
            rowhead.createCell(6).setCellValue("Средн");
            rowhead.createCell(7).setCellValue("Статус");
            
            Row currentRow1 = rowIterator1.next();
            Row currentRow2 = rowIterator2.next();
            //Тут ошибка NoSuchElementException
            Row currentRow3 = rowIterator3.next();
 
            while (rowIterator1.hasNext()) {
                rowIterator1.next();
                Iterator<Cell> cellIterator1 = currentRow1.iterator();
                Cell currentCell1 = cellIterator1.next();
                System.out.println(currentCell1);
                while (rowIterator2.hasNext()) {
                    rowIterator2.next();
                    Iterator<Cell> cellIterator2 = currentRow2.iterator();
                    Cell currentCell2 = cellIterator2.next();
                    System.out.println(currentCell2);
                    if(currentCell1.equals(currentCell2)) {
                        Iterator<Cell> cellIterator3 = currentRow3.iterator();
                        Cell currentCell3 = cellIterator3.next();
                        currentCell3.setCellValue(currentCell1.toString());
                        System.out.println(currentCell3);
                    }
                }
            }
            String filename = "D:/ResultQuarter.xls";
            FileOutputStream fileOut = new FileOutputStream(filename);
            workbook3.write(fileOut);
            fileOut.close();
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.05.2019, 16:43
Ответы с готовыми решениями:

Сравнение двух столбцов из разных файлов
Доброго времени суток! Не геракл в VBA, но возникла такая потребность: Есть 2 абсолютно одинаковые по структуре файла файл1.xls и...

Сравнение двух текстовых файлов и вывод уникальных строк в третий файл
Здравствуйте необходим батник, который сравнивает два текстовых файла и выводит уникальные строки в третий. Только есть небольшой нюанс,...

Сравнение двух столбцов с выводом в третий
Всем привет. Прошу помочь с задачкой. Есть два столбца, первый может содержать до 70-80 тыс. значений, второй содержит 50-1000 значений....

1
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
24.05.2019, 17:46
читаешь первую строку, делаешь split, находишь индекс нужного столбца
читаешь остальные строки, делаешь сплит, достаешь по найденному индексу нужное поле
сравниваешь
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.05.2019, 17:46
Помогаю со студенческими работами здесь

Данные из двух разных столбцов упорядочить и перенести в третий столбец
Здравствуйте! Помогите сделать отдельную кнопку в excel, которая бы все данные из двух разных столбцов упорядочивала и относила бы в...

Построчное сравнение тестовых файлов и запись дубликатов в третий
Есть 2 .txt файла, нужно сравнить каждую строку и записать количество одинаковых строк в 3 файл. Если есть код - скиньте, пожалуйста. А то...

Сравнение двух столбцов в разных файлах
добрый день есть два файла экселя каждый из 5 столбцов Наименование столбцов одинаковые но соответственно данные разные Количество...

Сравнение двух столбцов из разных книг
Здравствуйте глубокоуважаемые... Нужна помощь в написании VBA скрипта... Вообщем есть 2 книги Excel... Нужно сравнить два столбца из 2-х...

Сравнение и распределение двух столбцов на разных листах
Всем привет! Задача довольно банальна: сравнить столбец &quot;Идентификационный номер (2)&quot; на 2-м листе с столбцом &quot;Идентификационный...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru