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