배경
필요 오늘 보낸 엑셀 함수를 작성하지만, 발견하는 경우 30,000 데이터의 양, 메모리 밖으로 (23)의 열 수, CPU 100 %, 테스트 환경에 직접 타격. 3000 개 데이터, 500M 주위에 힙 메모리의 일시적인 증가 주위의 로컬 테스트, 수출에서 발견. 그리고 발견 SXSSFWorkbook
클래스를.
간략한 소개
SXSSFWorkbook
필요가 poi-ooxml
팩 3.8
과 위의를 지원하기 시작했다, 내 옆에이 사용에 적합한 3.9
버전, 기본적으로 XSSFWorkbook
클래스 ( Excel2007
)하는 방식이 채택 될하는 데 硬盘空间
크게 감소로 堆内存
, 풋 프린트를 시스템 디렉토리를 임시 폴더에 임시 파일을 생성하고 모든 더 큰 데이터의 행이 임시 파일에 저장되지만 모든 메모리에만 저장하는 메모리 합의 된 수보다 최신 순서로, 데이터 계약의 조각의 수는 메모리 공간에 대한 하드 디스크 공간을 달성하기 위해 메모리 부족 현상을 방지 할 수 있습니다
용도
일반 유도 방법에서 엑셀 구별, 그냥 인스턴스화 한 바뀌SXSSFWorkbook
SXSSFWorkbook workbook = null;
OutputStream outputStream = null;
try {
outputStream = response.getOutputStream();
//创建工作簿
workbook = new SXSSFWorkbook();
// 打开压缩功能 防止占用过多磁盘
workbook.setCompressTempFiles(true);
// 创建一个工作表
Sheet sheet = workbook.createSheet("表名");
// 创建一行
Row titleRow = sheet.createRow(0);
// 创建一个单元格
Cell cell = titleRow.createCell(0);
// 给单元格赋值
cell.setCellValue("内容");
// 将工作簿写入输出流
workbook.write(outputStream);
} catch (Exception e) {
e.printStackTrace();
}finally {
if (workbook != null) {
//使用完毕后将产生的临时文件删除 防止将磁盘搞满
workbook.dispose();
}
if (outputStream != null) {
outputStream.close();
}
}
复制代码
주의 사항
-
바람직하게는, 압축 모드가 켜져
workbook.setCompressTempFiles(true);
임시 파일이 크게 볼륨을 줄일 수 있도록하는 것이 -
사용 후 출시
workbook.dispose();
임시 파일을 방지하기 위해 하드 디스크를 폭발 증가되었습니다