Apache POI – 글꼴

이 장에서는 Excel 스프레드 시트에서 다른 글꼴을 설정하고, 스타일을 적용하고, 텍스트를 다른 각도로 표시하는 방법에 대해 설명합니다.

모든 시스템에는 Arial, Impact, Times New Roman 등과 같은 방대한 글꼴 모음이 번들로 제공됩니다. 필요한 경우 컬렉션을 새 글꼴로 업데이트 할 수도 있습니다. 마찬가지로 글꼴을 표시 할 수있는 다양한 스타일이 있습니다 (예 : 굵게, 기울임 꼴, 밑줄, 취소 선 등).

글꼴 및 글꼴 스타일

다음 코드는 특정 글꼴과 스타일을 셀 내용에 적용하는 데 사용됩니다.

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

import org.apache.poi.hssf.util.HSSFColor;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFCellStyle;
import org.apache.poi.xssf.usermodel.XSSFFont;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class FontStyle {
   public static void main(String[] args)throws Exception {
      XSSFWorkbook workbook = new XSSFWorkbook(); 
      XSSFSheet spreadsheet = workbook.createSheet("Fontstyle");
      XSSFRow row = spreadsheet.createRow(2);

      //Create a new font and alter it.
      XSSFFont font = workbook.createFont();
      font.setFontHeightInPoints((short) 30);
      font.setFontName("IMPACT");
      font.setItalic(true);
      font.setColor(HSSFColor.BRIGHT_GREEN.index);

      //Set font into style
      XSSFCellStyle style = workbook.createCellStyle();
      style.setFont(font);

      // Create a cell with a value and set style to it.
      XSSFCell cell = row.createCell(1);
      cell.setCellValue("Font Style");
      cell.setCellStyle(style);
      
      FileOutputStream out = new FileOutputStream(new File("fontstyle.xlsx"));
      workbook.write(out);
      out.close();
      System.out.println("fontstyle.xlsx written successfully");
   }
}

위의 코드를 다음과 같은 파일에 저장하겠습니다. FontStyle.java. 다음과 같이 명령 프롬프트에서 컴파일하고 실행하십시오.

$javac FontStyle.java
$java FontStyle

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

fontstyle.xlsx written successfully

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

텍스트 방향

여기에서 텍스트 방향을 다른 각도로 설정하는 방법을 배울 수 있습니다. 일반적으로 셀 내용은 수평으로, 왼쪽에서 오른쪽으로, 00 각도로 표시됩니다. 그러나 필요한 경우 다음 코드를 사용하여 텍스트 방향을 회전 할 수 있습니다.

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

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

public class TextDirection {
   public static void main(String[] args)throws Exception {
      XSSFWorkbook workbook = new XSSFWorkbook(); 
      XSSFSheet spreadsheet = workbook.createSheet("Text direction");
      XSSFRow row = spreadsheet.createRow(2);
      XSSFCellStyle myStyle = workbook.createCellStyle();
      myStyle.setRotation((short) 0);
      XSSFCell cell = row.createCell(1);
      cell.setCellValue("0D angle");
      cell.setCellStyle(myStyle);

      //30 degrees
      myStyle = workbook.createCellStyle();
      myStyle.setRotation((short) 30);
      cell = row.createCell(3);
      cell.setCellValue("30D angle");
      cell.setCellStyle(myStyle);

      //90 degrees
      myStyle = workbook.createCellStyle();
      myStyle.setRotation((short) 90);
      cell = row.createCell(5);
      cell.setCellValue("90D angle");
      cell.setCellStyle(myStyle);

      //120 degrees
      myStyle = workbook.createCellStyle();
      myStyle.setRotation((short) 120);
      cell = row.createCell(7);
      cell.setCellValue("120D angle");
      cell.setCellStyle(myStyle);

      //270 degrees
      myStyle = workbook.createCellStyle();
      myStyle.setRotation((short) 270);
      cell = row.createCell(9);
      cell.setCellValue("270D angle");
      cell.setCellStyle(myStyle);

      //360 degrees
      myStyle = workbook.createCellStyle();
      myStyle.setRotation((short) 360);
      cell = row.createCell(12);
      cell.setCellValue("360D angle");
      cell.setCellStyle(myStyle);
      
      FileOutputStream out = new FileOutputStream(new File("textdirection.xlsx"));
      workbook.write(out);
      out.close();
      System.out.println("textdirection.xlsx written successfully");
   }
}

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

$javac TextDirection.java
$java TextDirection

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

textdirection.xlsx written successfully

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