Apache POI - फ़ॉन्ट्स

यह अध्याय बताता है कि कैसे एक्सेल स्प्रेडशीट में अलग-अलग फॉन्ट सेट करना, स्टाइल लगाना और टेक्स्ट को दिशा के विभिन्न कोणों में प्रदर्शित करना है।

एरियल, इम्पैक्ट, टाइम्स न्यू रोमन इत्यादि जैसे फोंट के विशाल संग्रह के साथ हर प्रणाली बंडल में आ जाती है। आवश्यकता पड़ने पर नए फोंट के साथ संग्रह को अपडेट भी किया जा सकता है। इसी तरह विभिन्न शैलियों में एक फ़ॉन्ट प्रदर्शित किया जा सकता है, उदाहरण के लिए, बोल्ड, इटैलिक, अंडरलाइन, स्ट्राइक थ्रू, आदि।

फ़ॉन्ट्स और फ़ॉन्ट शैलियाँ

सेल की सामग्री के लिए एक विशेष फ़ॉन्ट और शैली लागू करने के लिए निम्न कोड का उपयोग किया जाता है।

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

यह एक एक्सेल फाइल बनाता है जिसका नाम है 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

यह नाम की एक एक्सेल फाइल बनाने के लिए संकलित और निष्पादित करेगा textdirection.xlsx अपनी वर्तमान निर्देशिका में और कमांड प्रॉम्प्ट पर निम्न आउटपुट प्रदर्शित करें।

textdirection.xlsx written successfully

textdirection.xlsx फ़ाइल निम्नानुसार है।