- 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);