자바 POI는 Excel을 사용하여 많은 양의 데이터를 내보낼

배경

필요 오늘 보낸 엑셀 함수를 작성하지만, 발견하는 경우 30,000 데이터의 양, 메모리 밖으로 (23)의 열 수, CPU 100 %, 테스트 환경에 직접 타격. 3000 개 데이터, 500M 주위에 힙 메모리의 일시적인 증가 주위의 로컬 테스트, 수출에서 발견. 그리고 발견 SXSSFWorkbook클래스를.

간략한 소개

SXSSFWorkbook필요가 poi-ooxml3.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();임시 파일을 방지하기 위해 하드 디스크를 폭발 증가되었습니다

추천

출처juejin.im/post/5dd66fea6fb9a05a987e8a9f