Apache POI – 공식

이 장에서는 Java 프로그래밍을 사용하여 셀에 다른 수식을 적용하는 프로세스를 안내합니다. Excel 응용 프로그램의 기본 목적은 수식을 적용하여 수치 데이터를 유지하는 것입니다.

수식에서 Excel 시트에있는 값의 동적 값 또는 위치를 전달합니다. 이 공식을 실행하면 원하는 결과를 얻을 수 있습니다. 다음 표에는 Excel에서 자주 사용되는 몇 가지 기본 수식이 나와 있습니다.

조작 통사론
여러 번호 추가 = SUM (Loc1 : Locn) or = SUM (n1, n2,)
카운트 = COUNT (Loc1 : Locn) or = COUNT (n1, n2,)
두 수의 거듭 제곱 = POWER (Loc1, Loc2) or = POWER (숫자, 거듭 제곱)
최대 여러 숫자 = MAX (Loc1 : Locn) or = MAX (n1, n2,)
생성물 = PRODUCT (Loc1 : Locn) or = PRODUCT (n1, n2,)
계승 = FACT (Locn) or = FACT (숫자)
절대 숫자 = ABS (Locn) or = ABS (숫자)
오늘 날짜 = 오늘 ()
소문자로 변환 = LOWER (Locn) or = LOWER (텍스트)
제곱근 = SQRT (위치) or = SQRT (숫자)

다음 코드는 셀에 수식을 추가하고 실행하는 데 사용됩니다.

import java.io.File;
import java.io.FileOutputStream;

import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class Formula {
   public static void main(String[] args)throws Exception {
      XSSFWorkbook workbook = new XSSFWorkbook(); 
      XSSFSheet spreadsheet = workbook.createSheet("formula");
      XSSFRow row = spreadsheet.createRow(1);
      XSSFCell cell = row.createCell(1);
      
      cell.setCellValue("A = ");
      cell = row.createCell(2);
      cell.setCellValue(2);
      row = spreadsheet.createRow(2);
      cell = row.createCell(1);
      cell.setCellValue("B = ");
      cell = row.createCell(2);
      cell.setCellValue(4);
      row = spreadsheet.createRow(3);
      cell = row.createCell(1);
      cell.setCellValue("Total = ");
      cell = row.createCell(2);
      
      // Create SUM formula
      cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
      cell.setCellFormula("SUM(C2:C3)");
      cell = row.createCell(3);
      cell.setCellValue("SUM(C2:C3)");
      row = spreadsheet.createRow(4);
      cell = row.createCell(1);
      cell.setCellValue("POWER =");
      cell=row.createCell(2);
      
      // Create POWER formula
      cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
      cell.setCellFormula("POWER(C2,C3)");
      cell = row.createCell(3);
      cell.setCellValue("POWER(C2,C3)");
      row = spreadsheet.createRow(5);
      cell = row.createCell(1);
      cell.setCellValue("MAX = ");
      cell = row.createCell(2);
      
      // Create MAX formula
      cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
      cell.setCellFormula("MAX(C2,C3)");
      cell = row.createCell(3);
      cell.setCellValue("MAX(C2,C3)");
      row = spreadsheet.createRow(6);
      cell = row.createCell(1);
      cell.setCellValue("FACT = ");
      cell = row.createCell(2);
      
      // Create FACT formula
      cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
      cell.setCellFormula("FACT(C3)");
      cell = row.createCell(3);
      cell.setCellValue("FACT(C3)");
      row = spreadsheet.createRow(7);
      cell = row.createCell(1);
      cell.setCellValue("SQRT = ");
      cell = row.createCell(2);
      
      // Create SQRT formula
      cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
      cell.setCellFormula("SQRT(C5)");
      cell = row.createCell(3);
      cell.setCellValue("SQRT(C5)");
      workbook.getCreationHelper().createFormulaEvaluator().evaluateAll();
      FileOutputStream out = new FileOutputStream(new File("formula.xlsx"));
      workbook.write(out);
      out.close();
      System.out.println("fromula.xlsx written successfully");
   }
}

위의 코드를 다른 이름으로 저장하십시오. Formula.java 다음과 같이 명령 프롬프트에서 컴파일하고 실행하십시오.

$javac Formula.java
$java Formula

이름이 Excel 파일을 생성합니다. formula.xlsx 현재 디렉토리에서 명령 프롬프트에 다음 출력을 표시합니다.

fromula.xlsx written successfully

그만큼 formula.xlsx 파일은 다음과 같습니다.