|
0 / 0 / 0
Регистрация: 17.08.2016
Сообщений: 10
|
||||||
Загрузка больших xlsxl файлов (POI + SAXParser)20.02.2017, 13:39. Показов 1658. Ответов 14
Добрый день.
Столкнулся с проблемой загрузки крупных файлов ексель (400 000 строк по 20 колонок). POI чудовищно съедает больше гига оперативы и выводит ошибку OutOfMemory. Нашел решение на http://stackoverflow.com/quest... apache-poi
Однако, мой уровень знаний Junior, и понять весь чужой код не могу. Просьба к мастерам Java прокомментировать вышеизложенный код по строкам (что от куда и для чего)... Даже не могу понять откуда взять значения конкретных ячеек...
0
|
||||||
| 20.02.2017, 13:39 | |
|
Ответы с готовыми решениями:
14
Загрузка больших файлов Загрузка больших файлов Загрузка Больших Файлов |
|
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
|
|
| 20.02.2017, 14:10 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 17.08.2016
Сообщений: 10
|
|
| 20.02.2017, 14:27 [ТС] | |
|
xoraxax
Примитивно вставлял System.out.println("1") в методы @Override public void startRow(int rowNum) { } @Override public void endRow() { } @Override public void cell(String cellReference, String formattedValue) { } @Override public void headerFooter(String text, boolean isHeader, String tagName) Ничего не выводит... не понимаю почему не заходит даже туда... поэтому и пишу сюда )
0
|
|
|
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
|
|
| 20.02.2017, 14:54 | |
|
а ты читаешь вообще, что тебе пишут, когда ты пытаешься этот код запустить?
0
|
|
|
0 / 0 / 0
Регистрация: 17.08.2016
Сообщений: 10
|
|
| 20.02.2017, 15:07 [ТС] | |
|
Не понял... кто пишет?
0
|
|
|
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
|
|
| 20.02.2017, 15:19 | |
|
как ты запускаешь этот код?
0
|
|
|
0 / 0 / 0
Регистрация: 17.08.2016
Сообщений: 10
|
|
| 20.02.2017, 15:40 [ТС] | |
|
container = OPCPackage.open(file.getAbsolutePath());
Указываю абсолютный путь к файлу и запускаю... он отрабатывается и все... А где он хранит разпарсенные данные и как их забрать не знаю
0
|
|
|
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
|
||
| 20.02.2017, 15:43 | ||
|
Добавлено через 37 секунд из консоли, из иде, еще каким-то причудливым способом?
0
|
||
|
0 / 0 / 0
Регистрация: 17.08.2016
Сообщений: 10
|
|
| 20.02.2017, 16:14 [ТС] | |
|
Через idea
Добавлено через 1 минуту Shift f9
0
|
|
|
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
|
|
| 20.02.2017, 16:24 | |
|
так вот в идее появляется окошко run или debug, а в этом окошке обычно что-то написано (например исключения).
0
|
|
|
0 / 0 / 0
Регистрация: 17.08.2016
Сообщений: 10
|
|
| 20.02.2017, 16:27 [ТС] | |
|
Код компилируется без ошибок если вопрос в этом... даже вижу распарсенные данные по символьно... но как забрать их
0
|
|
|
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
|
||
| 20.02.2017, 16:31 | ||
|
в метод cell() пиши if (cellReference.equals("A1")) myArrayListForXLSData.add(formattedValue ) или какие-там параметры
0
|
||
|
0 / 0 / 0
Регистрация: 17.08.2016
Сообщений: 10
|
|
| 20.02.2017, 16:50 [ТС] | |
|
Я поначалу тоже нацелился на этот метод... и для теста вбил в метод system.out.println("1");
При компиляции ничего не вывело в консоли... я так понял что этот метод не отрабатывается
0
|
|
|
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
|
|
| 20.02.2017, 19:11 | |
|
только что проверил все отрабатывается
0
|
|
|
0 / 0 / 0
Регистрация: 17.08.2016
Сообщений: 10
|
|||||||||||
| 21.02.2017, 14:27 [ТС] | |||||||||||
|
Спасибо за уделенное время... завтра попробую, скопирую код полностью заного, надеюсь все отработает... а то голову уже сломал, почему не отрабатывается.
Добавлено через 10 часов 45 минут Можешь вставить код с имортируемыми библиотеками? Сравню библиотеки... Добавлено через 1 час 40 минут Добавлено через 8 минут Вот полный код, который я компилирую:
При компиляции list не заполняется ... так и не заходит в метод cell Добавлено через 5 часов 25 минут Итак нашел все таки решение моей проблемы... переписал код, теперь он читает все данные со всех листов файла Xlsx. Надеюсь кому-нибудь этот код поможет и сэкономит пару деньков головоломки:
0
|
|||||||||||
| 21.02.2017, 14:27 | |
|
Помогаю со студенческими работами здесь
15
Загрузка больших файлов Загрузка больших файлов на сервер Загрузка больших файлов на сервер Загрузка больших файлов на php Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
BOINC: 22 года — и всё ещё работает
Programma_Boinc 12.03.2026
BOINC: 22 года — и всё ещё работает
Дэвид Андерсон написал ретроспективу. Кратко: в 2001 году он ушёл из United Devices, где был CTO, и за несколько месяцев написал ядро BOINC — клиент, сервер,. . .
|
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога
Финальные проекты на Си и на C++:
hello-sdl3-c. zip
hello-sdl3-cpp. zip
Результат:
|
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога
MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
|
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд.
Даже если у вас. . .
|
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|