반응형

요청사항 중에 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

 

POI Image

POI 에 이미지 목록을 뿌려 주여야 한다. poi3 버전부터 지원한다고 하는 것 같다. 이미 오래전.. public void downImgExcel(){ // Create the drawing patriarch. This is the top level container for all shapes. //객체를 하나만

godbasic.tistory.com

 

728x90
반응형

클래스는 클라이언트에 public 생성자 대신 (혹은 생성자와 함께) 정적 팩터리 메서드를 제공할 수 있다. 

장점 다섯 가지 

1. 이름을 가질 수 있다. 

2. 호출될 때마다 인스턴스를 새로 생성하지 않아도 된다. 

3. 반환 타입의 하위 타입 객체를 반환할 수 있는 능력이 있다.

4. 입력 매개변수에 따라 매번 다른 클래스의 객체를 반환할 수 있다. 

5. 정적 팩터리 메서드를 작성하는 시점에는 반환할 객체의 클래스가 존재하지 않아도 된다. 

단점 

1. 상속을 하려면 public이나 protected 생성자가 필요하니 정적 팩터리 메서드만 제공하면 하위 클래스를 만들 수 없다.

2.  정적 팩터리 메서드는 프로그래머가 찾기 어렵다.

 

- 출처 : 이펙티브 자바 Effective Java 3/E - 조슈아 블로크 저/개앞맵시  인사이트(insight)

728x90
반응형

Map안에 해당 키가 존재하는 갯수를 확인하는 로직의 경우

기존

Map<String, Integer> carInventory = new HashMap<>();
Integer count = 0; 
if(map.containsKey("Aston Martin")) {
	count = map.get("Aston Martin");
}

새로운 메서드

Integer count = map.getOrDefault("Aston Martin", 0);
728x90

+ Recent posts