Apache POI – 스프레드 시트

이 장에서는 스프레드 시트를 만들고 Java를 사용하여 조작하는 방법에 대해 설명합니다. 스프레드 시트는 Excel 파일의 페이지입니다. 특정 이름을 가진 행과 열을 포함합니다.

이 장을 마치면 스프레드 시트를 만들고 읽기 작업을 수행 할 수 있습니다.

스프레드 시트 만들기

우선, 이전 장에서 논의한 참조 클래스를 사용하여 스프레드 시트를 작성하겠습니다. 이전 장에 따라 먼저 통합 문서를 만든 다음 계속해서 시트를 만들 수 있습니다.

다음 코드 조각은 스프레드 시트를 만드는 데 사용됩니다.

//Create Blank workbook
XSSFWorkbook workbook = new XSSFWorkbook();

//Create a blank spreadsheet
XSSFSheet spreadsheet = workbook.createSheet("Sheet Name");

스프레드 시트의 행

스프레드 시트에는 그리드 레이아웃이 있습니다. 행과 열은 특정 이름으로 식별됩니다. 열은 알파벳으로 식별되고 행은 숫자로 식별됩니다.

다음 코드 스 니펫은 행을 만드는 데 사용됩니다.

XSSFRow row = spreadsheet.createRow((short)1);

스프레드 시트에 쓰기

직원 데이터의 예를 살펴 보겠습니다. 여기서 직원 데이터는 표 형식으로 제공됩니다.

Emp ID Emp 이름 지정
Tp01 고팔 기술 관리자
TP02 마니 샤 증거 판독기
Tp03 Masthan 기술 작가
Tp04 Satish 기술 작가
Tp05 크리슈나 기술 작가

다음 코드는 위의 데이터를 스프레드 시트에 쓰는 데 사용됩니다.

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

import java.util.Map;
import java.util.Set;
import java.util.TreeMap;

import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class Writesheet {
   public static void main(String[] args) throws Exception {

      //Create blank workbook
      XSSFWorkbook workbook = new XSSFWorkbook(); 

      //Create a blank sheet
      XSSFSheet spreadsheet = workbook.createSheet(" Employee Info ");

      //Create row object
      XSSFRow row;

      //This data needs to be written (Object[])
      Map < String, Object[] > empinfo = 
      new TreeMap < String, Object[] >();
      empinfo.put( "1", new Object[] { "EMP ID", "EMP NAME", "DESIGNATION" });
      empinfo.put( "2", new Object[] { "tp01", "Gopal", "Technical Manager" });
      empinfo.put( "3", new Object[] { "tp02", "Manisha", "Proof Reader" });
      empinfo.put( "4", new Object[] { "tp03", "Masthan", "Technical Writer" });
      empinfo.put( "5", new Object[] { "tp04", "Satish", "Technical Writer" });
      empinfo.put( "6", new Object[] { "tp05", "Krishna", "Technical Writer" });
      
      //Iterate over data and write to sheet
      Set < String > keyid = empinfo.keySet();
      int rowid = 0;

      for (String key : keyid) {
         row = spreadsheet.createRow(rowid++);
         Object [] objectArr = empinfo.get(key);
         int cellid = 0;

         for (Object obj : objectArr) {
            Cell cell = row.createCell(cellid++);
            cell.setCellValue((String)obj);
         }
      }

      //Write the workbook in file system
      FileOutputStream out = new FileOutputStream(new File("Writesheet.xlsx"));
      workbook.write(out);
      out.close();
      System.out.println("Writesheet.xlsx written successfully");
   }
}

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

$javac Writesheet.java
$java Writesheet

컴파일 및 실행되어 다음과 같은 Excel 파일을 생성합니다. Writesheet.xlsx 현재 디렉토리에 있고 명령 프롬프트에 다음 출력이 표시됩니다.

Writesheet.xlsx written successfully

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

스프레드 시트에서 읽기

위의 엑셀 파일을 고려해 보겠습니다. Writesheet.xslx입력으로. 다음 코드를 관찰하십시오. 스프레드 시트에서 데이터를 읽는 데 사용됩니다.

import java.io.File;
import java.io.FileInputStream;

import java.util.Iterator;

import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class Readsheet {
   static XSSFRow row;
   public static void main(String[] args) throws Exception {
      FileInputStream fis = new FileInputStream(new File("WriteSheet.xlsx"));
      
      XSSFWorkbook workbook = new XSSFWorkbook(fis);
      XSSFSheet spreadsheet = workbook.getSheetAt(0);
      Iterator < Row >  rowIterator = spreadsheet.iterator();
      
      while (rowIterator.hasNext()) {
         row = (XSSFRow) rowIterator.next();
         Iterator < Cell >  cellIterator = row.cellIterator();
         
         while ( cellIterator.hasNext()) {
            Cell cell = cellIterator.next();
            
            switch (cell.getCellType()) {
               case Cell.CELL_TYPE_NUMERIC:
                  System.out.print(cell.getNumericCellValue() + " \t\t ");
                  break;
               
               case Cell.CELL_TYPE_STRING:
                  System.out.print(
                  cell.getStringCellValue() + " \t\t ");
                  break;
            }
         }
         System.out.println();
      }
      fis.close();
   }
}

위의 코드를 Readsheet.java 다음과 같이 명령 프롬프트에서 컴파일하고 실행하십시오.

$javac Readsheet.java
$java Readsheet

시스템 환경이 POI 라이브러리로 구성된 경우 컴파일 및 실행되어 명령 프롬프트에 다음 출력이 생성됩니다.

EMP ID   EMP NAME       DESIGNATION 
 tp01     Gopal       Technical Manager 
 tp02     Manisha     Proof Reader 
 tp03     Masthan     Technical Writer 
 tp04     Satish      Technical Writer 
 tp05     Krishna     Technical Writer