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

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

24.05.2019, 16:43. Показов 3246. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru