Skip to content

Latest commit

 

History

History
45 lines (39 loc) · 1.87 KB

README.md

File metadata and controls

45 lines (39 loc) · 1.87 KB

Fluent POI

  • poi를 래핑한 프로젝트
  • 외부 라이브러리와의 경계를 감싸고
  • 좀 더 추상화된 API로 가독성을 향상
this.excelMakeWrapper.newWorkbook()
                .newSheet()
                .addHead(new ExcelHead("가", "나", "다", "라"))
                .addHead(new ExcelRow("1", "2", "3", "4"))
                .addRows(new ExcelRows(new ExcelRow("11", "22", null, "하하하")))
                .merge(new MergeColumn().rowIdx(1).startColIdx(2).endColIdx(4))
                .merge(new MergeRow().colIdx(1).startRowIdx(2).endRowIdx(4))
                .merge(new Merge().startRowIdx(10).endRowIdx(20).startColIdx(10).endColIdx(20));

        OutputStream osw = new FileOutputStream("test.xlsx");
        this.excelMakeWrapper.exportWorkbook().write(osw);
  • 애노테이션 기반의 객체로 데이터 생성 예제
@AllArgsConstructor                    
private static class TestClass{        
    @Excel(head = "이름", priority = 11) 
    private String name;               
    @Excel(head = "나이", priority = 3)  
    private int age;                   
    @Excel(priority = 2)               
    private String email;              
    private String etc;                
}                                      

TestClass target1 = new TestClass("AA", 29, "[email protected]", "qqq");
        TestClass target2 = new TestClass("BB", 29, "[email protected]", "sss");
        TestClass target3 = new TestClass("CC", 29, "[email protected]", "aaa");

        this.excelMakeWrapper.newWorkbook()
                .newSheet()
                .addHead(ExcelHead.from(target1))
                .addHead(ExcelRow.from(target2))
                .addRows(ExcelRows.from(Arrays.asList(target1, target2, target3)));

        OutputStream osw = new FileOutputStream("test.xlsx");
        this.excelMakeWrapper.exportWorkbook().write(osw);