अपाचे POI - सेल
एक स्प्रेडशीट में आपके द्वारा दर्ज किया गया कोई भी डेटा हमेशा एक सेल में संग्रहीत होता है। हम सेल की पहचान करने के लिए पंक्तियों और स्तंभों के लेबल का उपयोग करते हैं। इस अध्याय में जावा प्रोग्रामिंग का उपयोग करके एक स्प्रेडशीट में कोशिकाओं में डेटा में हेरफेर करने का वर्णन किया गया है।
एक सेल बनाएँ
सेल बनाने से पहले आपको एक पंक्ति बनाने की आवश्यकता है। एक पंक्ति और कुछ नहीं बल्कि कोशिकाओं का एक संग्रह है।
सेल बनाने के लिए निम्न कोड स्निपेट का उपयोग किया जाता है।
//create new workbook
XSSFWorkbook workbook = new XSSFWorkbook();
//create spreadsheet with a name
XSSFSheet spreadsheet = workbook.createSheet("new sheet");
//create first row on a created spreadsheet
XSSFRow row = spreadsheet.createRow(0);
//create first cell on created row
XSSFCell cell = row.createCell(0);
कोशिकाओं के प्रकार
सेल प्रकार निर्दिष्ट करता है कि क्या सेल में तार, संख्यात्मक मान या सूत्र हो सकते हैं। एक स्ट्रिंग सेल संख्यात्मक मान नहीं पकड़ सकता है और एक संख्यात्मक सेल तार नहीं पकड़ सकता है। नीचे दिए गए प्रकार सेल, उनके मान और प्रकार सिंटैक्स हैं।
सेल मान का प्रकार | सिंटैक्स टाइप करें |
---|---|
रिक्त सेल मान | XSSFCell.CELL_TYPE_BLANK |
बूलियन सेल वैल्यू | XSSFCell.CELL.TYPE_BOOLEAN |
त्रुटि सेल मान | XSSFCell.CELL_TYPE_ERROR |
न्यूमेरिक सेल वैल्यू | XSSFCell.CELL_TYPE_NUMERIC |
स्ट्रिंग सेल मान | XSSFCell.CELL_TYPE_STRING |
स्प्रेडशीट में विभिन्न प्रकार के सेल बनाने के लिए निम्न कोड का उपयोग किया जाता है।
import java.io.File;
import java.io.FileOutputStream;
import java.util.Date;
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 TypesofCells {
public static void main(String[] args)throws Exception {
XSSFWorkbook workbook = new XSSFWorkbook();
XSSFSheet spreadsheet = workbook.createSheet("cell types");
XSSFRow row = spreadsheet.createRow((short) 2);
row.createCell(0).setCellValue("Type of Cell");
row.createCell(1).setCellValue("cell value");
row = spreadsheet.createRow((short) 3);
row.createCell(0).setCellValue("set cell type BLANK");
row.createCell(1);
row = spreadsheet.createRow((short) 4);
row.createCell(0).setCellValue("set cell type BOOLEAN");
row.createCell(1).setCellValue(true);
row = spreadsheet.createRow((short) 5);
row.createCell(0).setCellValue("set cell type ERROR");
row.createCell(1).setCellValue(XSSFCell.CELL_TYPE_ERROR );
row = spreadsheet.createRow((short) 6);
row.createCell(0).setCellValue("set cell type date");
row.createCell(1).setCellValue(new Date());
row = spreadsheet.createRow((short) 7);
row.createCell(0).setCellValue("set cell type numeric");
row.createCell(1).setCellValue(20 );
row = spreadsheet.createRow((short) 8);
row.createCell(0).setCellValue("set cell type string");
row.createCell(1).setCellValue("A String");
FileOutputStream out = new FileOutputStream(new File("typesofcells.xlsx"));
workbook.write(out);
out.close();
System.out.println("typesofcells.xlsx written successfully");
}
}
उपरोक्त कोड को एक फाइल में सेव करें TypesofCells.java, संकलन और इसे कमांड प्रॉम्प्ट से निम्नानुसार निष्पादित करें।
$javac TypesofCells.java
$java TypesofCells
यदि आपका सिस्टम POI लाइब्रेरी के साथ कॉन्फ़िगर किया गया है, तो यह नाम की एक एक्सेल फाइल बनाने के लिए संकलित और निष्पादित करेगा typesofcells.xlsx अपनी वर्तमान निर्देशिका में और निम्न आउटपुट प्रदर्शित करें।
typesofcells.xlsx written successfully
typesofcells.xlsx फ़ाइल निम्नानुसार है।
सेल शैलियाँ
यहां आप सीख सकते हैं कि सेल फ़ॉर्मेटिंग कैसे करें और विभिन्न शैलियों को लागू करें जैसे कि आसन्न कोशिकाओं को मर्ज करना, सीमाएँ जोड़ना, सेल संरेखण सेट करना और रंगों के साथ भरना।
निम्नलिखित कोड का उपयोग जावा प्रोग्रामिंग का उपयोग करके कोशिकाओं में विभिन्न शैलियों को लागू करने के लिए किया जाता है।
import java.io.File;
import java.io.FileOutputStream;
import org.apache.poi.hssf.util.HSSFColor;
import org.apache.poi.ss.usermodel.IndexedColors;
import org.apache.poi.ss.util.CellRangeAddress;
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 CellStyle {
public static void main(String[] args)throws Exception {
XSSFWorkbook workbook = new XSSFWorkbook();
XSSFSheet spreadsheet = workbook.createSheet("cellstyle");
XSSFRow row = spreadsheet.createRow((short) 1);
row.setHeight((short) 800);
XSSFCell cell = (XSSFCell) row.createCell((short) 1);
cell.setCellValue("test of merging");
//MEARGING CELLS
//this statement for merging cells
spreadsheet.addMergedRegion(
new CellRangeAddress(
1, //first row (0-based)
1, //last row (0-based)
1, //first column (0-based)
4 //last column (0-based)
)
);
//CELL Alignment
row = spreadsheet.createRow(5);
cell = (XSSFCell) row.createCell(0);
row.setHeight((short) 800);
// Top Left alignment
XSSFCellStyle style1 = workbook.createCellStyle();
spreadsheet.setColumnWidth(0, 8000);
style1.setAlignment(XSSFCellStyle.ALIGN_LEFT);
style1.setVerticalAlignment(XSSFCellStyle.VERTICAL_TOP);
cell.setCellValue("Top Left");
cell.setCellStyle(style1);
row = spreadsheet.createRow(6);
cell = (XSSFCell) row.createCell(1);
row.setHeight((short) 800);
// Center Align Cell Contents
XSSFCellStyle style2 = workbook.createCellStyle();
style2.setAlignment(XSSFCellStyle.ALIGN_CENTER);
style2.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER);
cell.setCellValue("Center Aligned");
cell.setCellStyle(style2);
row = spreadsheet.createRow(7);
cell = (XSSFCell) row.createCell(2);
row.setHeight((short) 800);
// Bottom Right alignment
XSSFCellStyle style3 = workbook.createCellStyle();
style3.setAlignment(XSSFCellStyle.ALIGN_RIGHT);
style3.setVerticalAlignment(XSSFCellStyle.VERTICAL_BOTTOM);
cell.setCellValue("Bottom Right");
cell.setCellStyle(style3);
row = spreadsheet.createRow(8);
cell = (XSSFCell) row.createCell(3);
// Justified Alignment
XSSFCellStyle style4 = workbook.createCellStyle();
style4.setAlignment(XSSFCellStyle.ALIGN_JUSTIFY);
style4.setVerticalAlignment(XSSFCellStyle.VERTICAL_JUSTIFY);
cell.setCellValue("Contents are Justified in Alignment");
cell.setCellStyle(style4);
//CELL BORDER
row = spreadsheet.createRow((short) 10);
row.setHeight((short) 800);
cell = (XSSFCell) row.createCell((short) 1);
cell.setCellValue("BORDER");
XSSFCellStyle style5 = workbook.createCellStyle();
style5.setBorderBottom(XSSFCellStyle.BORDER_THICK);
style5.setBottomBorderColor(IndexedColors.BLUE.getIndex());
style5.setBorderLeft(XSSFCellStyle.BORDER_DOUBLE);
style5.setLeftBorderColor(IndexedColors.GREEN.getIndex());
style5.setBorderRight(XSSFCellStyle.BORDER_HAIR);
style5.setRightBorderColor(IndexedColors.RED.getIndex());
style5.setBorderTop(XSSFCellStyle.BIG_SPOTS);
style5.setTopBorderColor(IndexedColors.CORAL.getIndex());
cell.setCellStyle(style5);
//Fill Colors
//background color
row = spreadsheet.createRow((short) 10 );
cell = (XSSFCell) row.createCell((short) 1);
XSSFCellStyle style6 = workbook.createCellStyle();
style6.setFillBackgroundColor(HSSFColor.LEMON_CHIFFON.index );
style6.setFillPattern(XSSFCellStyle.LESS_DOTS);
style6.setAlignment(XSSFCellStyle.ALIGN_FILL);
spreadsheet.setColumnWidth(1,8000);
cell.setCellValue("FILL BACKGROUNG/FILL PATTERN");
cell.setCellStyle(style6);
//Foreground color
row = spreadsheet.createRow((short) 12);
cell = (XSSFCell) row.createCell((short) 1);
XSSFCellStyle style7 = workbook.createCellStyle();
style7.setFillForegroundColor(HSSFColor.BLUE.index);
style7.setFillPattern( XSSFCellStyle.LESS_DOTS);
style7.setAlignment(XSSFCellStyle.ALIGN_FILL);
cell.setCellValue("FILL FOREGROUND/FILL PATTERN");
cell.setCellStyle(style7);
FileOutputStream out = new FileOutputStream(new File("cellstyle.xlsx"));
workbook.write(out);
out.close();
System.out.println("cellstyle.xlsx written successfully");
}
}
उपरोक्त कोड को एक फाइल में सेव करें CellStyle.java, संकलन और इसे कमांड प्रॉम्प्ट से निम्नानुसार निष्पादित करें।
$javac CellStyle.java
$java CellStyle
यह नाम की एक एक्सेल फाइल जेनरेट करेगा cellstyle.xlsx अपनी वर्तमान निर्देशिका में और निम्न आउटपुट प्रदर्शित करें।
cellstyle.xlsx written successfully
Cellstyle.xlsx फ़ाइल निम्नानुसार दिखती है।