[JAVA] Apache POI

요청 중에는 Excel에서 래스터 데이터에 이미지를 삽입하는 기능을 구현해 달라는 요청이 있었습니다.

제가 확인한 바로는 엑셀 내보내기 기능은 보통 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.entry/POI-Image

POI 이미지

사진 목록은 POI에 배포되어야 합니다. poi3 버전에서 지원하는 것 같습니다. 오래 전에… public void downImgExcel(){ // Patriarch 드로잉을 만듭니다. 이것은 모든 셰이프의 최상위 컨테이너입니다. // 그냥 객체

godbasic.tistory.com