반응형
요청사항 중에 grid 데이터에 이미지를 엑셀에 삽입하는 기능을 구현하기를 요청하였다.
찾아보니 excel export 기능은 보통 POI라이브러리를 이용한다고 한다.
int cellIndex=8;
Drawing drawing = sheet.createDrawingPatriarch();
for(FilesVO fileVO : filesVOList){
ExcelUtil.setImgCell(workbook, sheet, row.getRowNum(), cellIndex++, opinionUploadPath+"/"+fileVO.getFileReName(), drawing);
//Workbook interface, Sheet interface, 행, 열, 이미지 파일 경로, Drawing interface
}
import org.apache.poi.hssf.usermodel.HSSFClientAnchor;
import org.apache.poi.ss.usermodel.Drawing;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.util.IOUtils;
import java.io.FileInputStream;
import java.io.InputStream;
public class ExcelUtil {
public static void setImgCell(Workbook workbook, Sheet sheet, int row, int cell, String fileName, Drawing drawing) throws Exception{
InputStream is = new FileInputStream(fileName);
byte[] bytes = IOUtils.toByteArray(is);
int pictureIdx = workbook.addPicture(bytes, Workbook.PICTURE_TYPE_JPEG);
is.close();
HSSFClientAnchor anchor = new HSSFClientAnchor(2,2,1021,253,(short)cell,(row),(short)cell,(row));
anchor.setAnchorType(1);
drawing.createPicture(anchor, pictureIdx);
}
}
https://godbasic.tistory.com/entry/POI-Image
728x90
'[개발관련] > JAVA' 카테고리의 다른 글
[JAVA] ModelMapper 라이브러리 (0) | 2023.03.15 |
---|---|
[JAVA] JAVA stream filter 활용-List<Map<Long, Data>>에서 특정 key가진 데이터 추출 (0) | 2023.02.23 |
[이팩티브 자바 정리] 아이템 1 생성자 대신 정적 팩터리 메서드를 고려하라 (0) | 2022.07.09 |
모던자바인액션 추가 메서드 맵 (0) | 2022.06.23 |
javax.validation 어노테이션 정리 (0) | 2022.01.27 |