MS Excel 스프레드시트를 사용하면 많은 양의 표 형식 데이터를 더 쉽게 유지하고 공유할 수 있습니다. 뿐만 아니라 수식 적용, 차트 및 그래프 생성, 데이터 정렬 및 필터링 등과 같은 다양한 작업을 수행할 수 있습니다. 이 기사에서는 Java 애플리케이션 내에서 Excel 자동화 기능을 구현하는 방법을 배웁니다. 이 기사를 읽고 나면 Java를 사용하여 Excel XLSX 또는 XLS 파일을 처음부터 만들 수 있습니다. 또한 이 문서에서는 기존 Excel 파일을 업데이트하고, 차트를 생성하고, 수식을 적용하고, Excel 워크시트에 피벗 테이블을 추가하는 방법을 다룹니다.
- Excel 파일을 만드는 Java API
- Java를 사용하여 Excel XLSX 또는 XLS 파일 만들기
- Java를 사용하여 기존 Excel 파일 편집
- Java를 사용하여 Excel 파일에서 차트 만들기
- Java를 사용하여 XLSX에서 피벗 테이블 만들기
- Java를 사용하여 XLSX의 셀에 수식 추가
Excel 파일 생성을 위한 Java API - 무료 다운로드
Aspose.Cells for Java는 MS Office 없이 Excel 파일을 생성하거나 수정할 수 있는 강력한 스프레드시트 조작 API입니다. API는 차트, 그래프, 수식 추가를 지원하고 프로그래밍 방식으로 기타 스프레드시트 조작 작업을 수행합니다. API를 무료로 다운로드하거나 Maven 기반 애플리케이션에 설치할 수 있습니다.
<repository>
<id>AsposeJavaAPI</id>
<name>Aspose Java API</name>
<url>https://repository.aspose.com/repo/</url>
</repository>
<dependency>
<groupId>com.aspose</groupId>
<artifactId>aspose-cells</artifactId>
<version>20.9</version>
</dependency>
Java를 사용하여 Excel XLSX 또는 XLS 만들기
MS Excel 파일을 통합 문서라고 하며 각 통합 문서는 하나 이상의 워크시트로 구성됩니다. 워크시트에는 데이터를 셀 형태로 유지하기 위한 행과 열이 추가로 포함됩니다. 이제 간단한 통합 문서를 만드는 것으로 시작해 보겠습니다. 다음은 Excel XLSX 파일을 처음부터 만드는 단계입니다.
- Workbook 클래스의 인스턴스를 만듭니다.
- Workbook.getWorksheets.get() 메서드를 사용하여 원하는 워크시트에 액세스합니다.
- A1, B3 등과 같은 셀의 식별자를 사용하여 워크시트의 원하는 셀에 값을 입력합니다.
- Workbook.save() 메서드를 사용하여 통합 문서를 Excel 파일로 저장합니다.
다음 코드 샘플은 Java를 사용하여 Excel XLSX 파일을 만드는 방법을 보여줍니다.
// 새 통합 문서 만들기
Workbook workbook = new Workbook();
// 셀에 값 추가
workbook.getWorksheets().get(0).getCells().get("A1").putValue("Hello World!");
// Excel XLSX 파일로 저장
workbook.save("Excel.xlsx");
Java를 사용하여 Excel XLSX 파일 편집
이제 기존 MS Excel 파일에 데이터를 수정하거나 삽입하는 방법을 살펴보겠습니다. 이를 위해 단순히 파일을 로드하고 원하는 워크시트에 액세스하고 업데이트된 파일을 저장할 수 있습니다. 다음은 기존 Excel 파일을 수정하는 단계입니다.
- Workbook 클래스를 사용하여 Excel 파일을 엽니다.
- Worksheet 및 Cell 클래스를 각각 사용하여 워크시트와 셀에 액세스합니다.
- 업데이트된 통합 문서를 Excel .xlsx 파일로 저장합니다.
다음 코드 샘플은 Java를 사용하여 기존 MS Excel 파일을 편집하는 방법을 보여줍니다.
// 새 통합 문서 만들기
Workbook workbook = new Workbook("workbook.xls");
// 워크시트의 셀에서 "A1" 셀의 참조 가져오기
Cell cell = workbook.getWorksheets().get(0).getCells().get("A1");
// "Hello World!"를 설정하십시오. "A1" 셀에 값
cell.setValue("updated cell value.");
// 엑셀 파일 쓰기
workbook.save("Excel.xls", FileFormatType.EXCEL_97_TO_2003);
Java를 사용하여 Excel에서 차트 또는 그래프 만들기
스프레드시트의 차트는 워크시트에 저장된 데이터를 시각적으로 나타내는 데 사용됩니다. 많은 양의 데이터를 아주 쉽게 분석할 수 있습니다. Aspose.Cells for Java는 프로그래밍 방식으로 Excel 파일 내에서 생성할 수 있는 광범위한 차트를 제공합니다. 다음은 Excel XLSX 파일에서 차트를 만드는 단계입니다.
- Workbook 클래스를 사용하여 새 Excel 파일을 만들거나 기존 파일을 로드합니다.
- 워크시트에 데이터를 추가합니다(선택 사항).
- Worksheet.getCharts() 메서드를 사용하여 워크시트의 차트 모음을 가져옵니다.
- Worksheet.getCharts().add() 메서드를 사용하여 새 차트를 추가합니다.
- 컬렉션에서 새로 생성된 차트를 가져옵니다.
- 차트에 대해 NSeries를 설정할 셀의 범위를 지정합니다.
- 통합 문서를 Excel .xlsx 파일로 저장합니다.
다음 코드 샘플은 Java를 사용하여 Excel XLSX에서 차트를 만드는 방법을 보여줍니다.
// 새 통합 문서 만들기
Workbook workbook = new Workbook("workbook.xlsx");
// 첫 번째 워크시트의 참조 가져오기
WorksheetCollection worksheets = workbook.getWorksheets();
Worksheet sheet = worksheets.get(0);
// 셀에 일부 샘플 값 추가
Cells cells = sheet.getCells();
Cell cell = cells.get("A1");
cell.setValue(50);
cell = cells.get("A2");
cell.setValue(100);
cell = cells.get("A3");
cell.setValue(150);
cell = cells.get("B1");
cell.setValue(4);
cell = cells.get("B2");
cell.setValue(20);
cell = cells.get("B3");
cell.setValue(50);
// 워크시트에서 차트 가져오기
ChartCollection charts = sheet.getCharts();
// 워크시트에 차트 추가
int chartIndex = charts.add(ChartType.PYRAMID, 5, 0, 15, 5);
Chart chart = charts.get(chartIndex);
// "A1" 범위의 차트에 NSeries(차트 데이터 소스) 추가
// 셀을 "B3"으로
SeriesCollection serieses = chart.getNSeries();
serieses.add("A1:B3", true);
// 엑셀 파일 쓰기
workbook.save("Excel_with_Chart.xlsx");
Java를 사용하여 Excel XLSX에서 피벗 테이블 만들기
Excel 워크시트의 피벗 테이블은 데이터에 필터 추가, 합계 계산, 데이터 요약 등과 같은 다양한 목적을 가지고 있습니다. 피벗 테이블은 워크시트의 셀 범위를 사용하여 만들 수 있습니다. 다음은 Excel 워크시트에서 피벗 테이블을 만드는 단계입니다.
- 새 Workbook을 만들거나 기존 파일을 로드합니다.
- 워크시트에 데이터를 삽입합니다(선택 사항).
- Worksheet.getPivotTables() 메서드를 사용하여 피벗 테이블 컬렉션에 액세스합니다.
- Worksheet.getPivotTables().add() 메서드를 사용하여 워크시트에 새 피벗 테이블을 추가합니다.
- 피벗 테이블에 데이터를 제공합니다.
- 통합 문서를 저장합니다.
다음 코드 샘플은 Java를 사용하여 Excel에서 피벗 테이블을 만드는 방법을 보여줍니다.
// 새 통합 문서 만들기
Workbook workbook = new Workbook("workbook.xlsx");
// 첫 번째 워크시트를 가져옵니다.
Worksheet sheet = workbook.getWorksheets().get(0);
// 워크시트의 셀 컬렉션 가져오기
Cells cells = sheet.getCells();
// 값을 셀에 설정
Cell cell = cells.get("A1");
cell.setValue("Sport");
cell = cells.get("B1");
cell.setValue("Quarter");
cell = cells.get("C1");
cell.setValue("Sales");
cell = cells.get("A2");
cell.setValue("Golf");
cell = cells.get("A3");
cell.setValue("Golf");
cell = cells.get("A4");
cell.setValue("Tennis");
cell = cells.get("A5");
cell.setValue("Tennis");
cell = cells.get("A6");
cell.setValue("Tennis");
cell = cells.get("A7");
cell.setValue("Tennis");
cell = cells.get("A8");
cell.setValue("Golf");
cell = cells.get("B2");
cell.setValue("Qtr3");
cell = cells.get("B3");
cell.setValue("Qtr4");
cell = cells.get("B4");
cell.setValue("Qtr3");
cell = cells.get("B5");
cell.setValue("Qtr4");
cell = cells.get("B6");
cell.setValue("Qtr3");
cell = cells.get("B7");
cell.setValue("Qtr4");
cell = cells.get("B8");
cell.setValue("Qtr3");
cell = cells.get("C2");
cell.setValue(1500);
cell = cells.get("C3");
cell.setValue(2000);
cell = cells.get("C4");
cell.setValue(600);
cell = cells.get("C5");
cell.setValue(1500);
cell = cells.get("C6");
cell.setValue(4070);
cell = cells.get("C7");
cell.setValue(5000);
cell = cells.get("C8");
cell.setValue(6430);
PivotTableCollection pivotTables = sheet.getPivotTables();
// 워크시트에 피벗 테이블 추가
int index = pivotTables.add("=A1:C8", "E3", "PivotTable2");
// 새로 추가된 피벗 테이블의 인스턴스에 액세스
PivotTable pivotTable = pivotTables.get(index);
// 행의 총합계를 표시하지 않습니다.
pivotTable.setRowGrand(false);
// 첫 번째 필드를 행 영역으로 드래그합니다.
pivotTable.addFieldToArea(PivotFieldType.ROW, 0);
// 두 번째 필드를 열 영역으로 드래그합니다.
pivotTable.addFieldToArea(PivotFieldType.COLUMN, 1);
// 세 번째 필드를 데이터 영역으로 드래그합니다.
pivotTable.addFieldToArea(PivotFieldType.DATA, 2);
// 엑셀 파일 쓰기
workbook.save("Excel_with_Chart.xlsx");
Java를 사용하여 Excel 파일의 셀에 수식 추가
Java용 Aspose.Cells를 사용하면 Excel 워크시트의 수식으로 작업할 수도 있습니다. 내장 및 추가 기능을 셀에 적용할 수 있습니다.
Excel에서 기본 제공 함수 적용
내장 함수를 사용하려면 워크시트에서 원하는 셀에 접근하여 Cell.setFormula(String) 메서드를 사용하여 수식을 추가하면 됩니다. 다음 코드 샘플은 Java를 사용하여 내장 수식을 설정하는 방법을 보여줍니다.
// 새 통합 문서 만들기
Workbook workbook = new Workbook();
// 셀에 값 추가
workbook.getWorksheets().get(0).getCells().get(0).setFormula("=H7*(1+IF(P7 =$L$3,$M$3, (IF(P7=$L$4,$M$4,0))))");
// Excel XLSX 파일로 저장
workbook.save("Excel.xlsx");
Excel에서 추가 기능 추가
사용자 정의 함수를 사용해야 하는 경우가 있습니다. 이를 위해서는 .xlam(Excel 매크로 사용 추가 기능) 파일을 사용하여 추가 기능을 등록한 후 원하는 셀에 사용해야 합니다. 추가 기능 등록을 위해 자바용 Aspose.Cells는 registerAddInFunction(int, String) 및 registerAddInFunction(String, String, boolean) 메서드를 제공합니다. 다음 코드 샘플은 Java를 사용하여 추가 기능을 등록하고 사용하는 방법을 보여줍니다.
// 새 통합 문서 만들기
Workbook workbook = new Workbook();
// 기능 이름과 함께 매크로 사용 추가 기능 등록
int id = workbook.getWorksheets().registerAddInFunction("TESTUDF.xlam", "TEST_UDF", false);
// 파일에 더 많은 기능 등록(있는 경우)
workbook.getWorksheets().registerAddInFunction(id, "TEST_UDF1"); //in this way you can add more functions that are in the same file
// 첫 번째 워크시트에 액세스
Worksheet worksheet = workbook.getWorksheets().get(0);
// 첫 번째 셀에 액세스
Cell cell = worksheet.getCells().get("A1");
// 추가 기능에 있는 수식 이름 설정
cell.setFormula("=TEST_UDF()");
// Excel XLSX 파일로 저장
workbook.save("Excel.xlsx");
결론
이 기사에서는 MS Office 없이 Java를 사용하여 처음부터 MS Excel 파일을 만드는 방법을 살펴보았습니다. 또한 통합 문서를 업데이트하고, 차트를 만들고, 표를 추가하고, MS Excel 워크시트 내의 셀 값에 수식을 적용하는 방법을 배웠습니다. 문서를 사용하여 Aspose의 Java Excel API에 대해 자세히 알아볼 수 있습니다.