250x250
Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- Core Java
- error
- myBatis
- Spring Boot
- Open Source
- Exception
- JavaScript
- Docker
- ubuntu
- 오픈소스
- MySQL
- git
- Source
- 문서
- SpringBoot
- STS
- Thymeleaf
- JDBC
- MSSQL
- 설정
- Python
- AJAX
- jpa
- Eclipse
- Tomcat
- PostgreSQL
- spring
- maven
- IntelliJ
- oracle
Archives
- Today
- Total
헤르메스 LIFE
[Excel] 대용량 Excel 파일 읽기 - 수정 본문
728x90
POI를 이용한 Excel 파일 Loading 을 조금 수정했습니다.
파일의 내용은 아직까지 좋은 것 같습니다. 그런데.. deprecated 된 내용이 있기도 하고..
여러개의 Sheet를 읽지 못하는 것도 있어서 해당 내용만 수정했습니다.
ExcelSheetHandler.java
package simple.spring.handler;
import java.io.File;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.apache.poi.hssf.util.CellReference;
import org.apache.poi.openxml4j.opc.OPCPackage;
import org.apache.poi.xssf.binary.XSSFBSheetHandler.SheetContentsHandler;
import org.apache.poi.xssf.eventusermodel.ReadOnlySharedStringsTable;
import org.apache.poi.xssf.eventusermodel.XSSFReader;
import org.apache.poi.xssf.eventusermodel.XSSFSheetXMLHandler;
import org.apache.poi.xssf.model.StylesTable;
import org.apache.poi.xssf.usermodel.XSSFComment;
import org.xml.sax.ContentHandler;
import org.xml.sax.InputSource;
import org.xml.sax.XMLReader;
/**
* <pre>
* 출처 : https://javavoa-mok.tistory.com/58
* </pre>
*
* @author hermeswing
*/
public class ExcelSheetHandler implements SheetContentsHandler {
private int currentCol = -1;
private int currRowNum = 0;
String filePath = "";
private List<List<String>> rows = new ArrayList<>(); // 실제 엑셀을 파싱해서 담아지는 데이터
private List<String> row = new ArrayList<>();
private List<String> header = new ArrayList<>();
public static ExcelSheetHandler readExcel( File file ) throws Exception {
ExcelSheetHandler sheetHandler = new ExcelSheetHandler();
try {
// org.apache.poi.openxml4j.opc.OPCPackage
OPCPackage opc = OPCPackage.open(file);
// org.apache.poi.xssf.eventusermodel.XSSFReader
XSSFReader xssfReader = new XSSFReader(opc);
// org.apache.poi.xssf.model.StylesTable
StylesTable styles = xssfReader.getStylesTable();
// org.apache.poi.xssf.eventusermodel.ReadOnlySharedStringsTable
ReadOnlySharedStringsTable strings = new ReadOnlySharedStringsTable(opc);
// 엑셀의 시트를 하나만 가져오기입니다.
// 여러개일경우 while문으로 추출하셔야 됩니다.
InputStream inputStream = xssfReader.getSheetsData().next();
// org.xml.sax.InputSource
InputSource inputSource = new InputSource(inputStream);
// org.xml.sax.Contenthandler
ContentHandler handle = new XSSFSheetXMLHandler(styles, strings, sheetHandler, false);
// XMLReader xmlReader = SAXHelper.newXMLReader(); // deprecated
SAXParserFactory saxParserFactory = SAXParserFactory.newInstance();
saxParserFactory.setNamespaceAware(true);
SAXParser parser = saxParserFactory.newSAXParser();
XMLReader xmlReader = parser.getXMLReader();
xmlReader.setContentHandler(handle);
xmlReader.parse(inputSource);
inputStream.close();
opc.close();
} catch (Exception e) {
// 에러 발생했을때 하시고 싶은 TO-DO
}
return sheetHandler;
}// readExcel - end
public static List<ExcelSheetHandler> readSheets( File file ) throws Exception {
List<ExcelSheetHandler> sheetHandlers = new ArrayList<>();
try {
// org.apache.poi.openxml4j.opc.OPCPackage
OPCPackage opc = OPCPackage.open(file);
// org.apache.poi.xssf.eventusermodel.XSSFReader
XSSFReader xssfReader = new XSSFReader(opc);
// org.apache.poi.xssf.model.StylesTable
StylesTable styles = xssfReader.getStylesTable();
// org.apache.poi.xssf.eventusermodel.ReadOnlySharedStringsTable
ReadOnlySharedStringsTable strings = new ReadOnlySharedStringsTable(opc);
ExcelSheetHandler sheetHandler = null;
InputStream inputStream = null;
InputSource inputSource = null;
ContentHandler handle = null;
XSSFReader.SheetIterator sheets = (XSSFReader.SheetIterator) xssfReader.getSheetsData();
while (sheets.hasNext()) {
// 엑셀의 시트를 하나만 가져오기입니다.
// 여러개일경우 while문으로 추출하셔야 됩니다.
inputStream = xssfReader.getSheetsData().next();
// org.xml.sax.InputSource
inputSource = new InputSource(inputStream);
// org.xml.sax.Contenthandler
handle = new XSSFSheetXMLHandler(styles, strings, sheetHandler, false);
// XMLReader xmlReader = SAXHelper.newXMLReader(); // deprecated
SAXParserFactory saxParserFactory = SAXParserFactory.newInstance();
saxParserFactory.setNamespaceAware(true);
SAXParser parser = saxParserFactory.newSAXParser();
XMLReader xmlReader = parser.getXMLReader();
xmlReader.setContentHandler(handle);
xmlReader.parse(inputSource);
inputStream.close();
}
opc.close();
} catch (Exception e) {
// 에러 발생했을때 하시고 싶은 TO-DO
}
return sheetHandlers;
}// readExcel - end
public List<List<String>> getRows() {
return rows;
}
@Override
public void startRow( int arg0 ) {
this.currentCol = -1;
this.currRowNum = arg0;
}
@Override
public void cell( String columnName, String value, XSSFComment var3 ) {
int iCol = (new CellReference(columnName)).getCol();
int emptyCol = iCol - currentCol - 1;
for ( int i = 0; i < emptyCol; i++ ) {
row.add("");
}
currentCol = iCol;
row.add(value);
}
@Override
public void headerFooter( String arg0, boolean arg1, String arg2 ) {
// 사용안합니다.
}
@Override
public void endRow( int rowNum ) {
if ( rowNum == 0 ) {
header = new ArrayList(row);
} else {
if ( row.size() < header.size() ) {
for ( int i = row.size(); i < header.size(); i++ ) {
row.add("");
}
}
rows.add(new ArrayList(row));
}
row.clear();
}
@Override
public void hyperlinkCell( String arg0, String arg1, String arg2, String arg3, XSSFComment arg4 ) {
// TODO Auto-generated method stub
}
}
https://hermeslog.tistory.com/433
728x90
'Core Java' 카테고리의 다른 글
[ModelMapper] Object to Object 매핑 (0) | 2023.04.26 |
---|---|
[개발환경] Eclipse 에서 Gradle 기반의 Java 프로젝트 생성하기 (0) | 2023.04.26 |
[Java] 날짜 계산 Tip (0) | 2022.12.03 |
[JSP] session 객체 (0) | 2022.12.03 |
자바 프로그래머가 자주 실수 하는 10가지 (0) | 2022.12.03 |