अपाचे POI - सूत्र

यह अध्याय आपको जावा प्रोग्रामिंग का उपयोग करके कोशिकाओं पर विभिन्न सूत्रों को लागू करने की प्रक्रिया के माध्यम से लेता है। एक्सेल एप्लिकेशन का मूल उद्देश्य इस पर सूत्र लगाकर संख्यात्मक डेटा बनाए रखना है।

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

ऑपरेशन वाक्य - विन्यास
कई संख्याएँ जोड़ना = एसयूएम (लोके 1: लोकेन) or = एसयूएम (एन 1, एन 2)
गिनती = COUNT (लोके 1: लोकेन) or = COUNT (n1, n2)
दो संख्याओं की शक्ति = पॉवर (Loc1, Loc2) or = शक्ति (संख्या, शक्ति)
कई नंबरों का मैक्स = MAX (Loc1: लोचन) or = मैक्स (एन 1, एन 2)
उत्पाद = उत्पाद (Loc1: लोचन) or = उत्पाद (एन 1, एन 2)
कारख़ाने का = तथ्य (लोचन) or = तथ्य (संख्या)
पूर्ण संख्या = ABS (लोचन) or = ABS (संख्या)
आज की तारीख़ = आज ()
लोअरकेस को परिवर्तित करता है = कम (लोचन) or = कम (पाठ)
वर्गमूल = SQRT (लोचन) or = SQRT (संख्या)

निम्न कोड का उपयोग किसी कक्ष में सूत्र जोड़ने और उसे निष्पादित करने के लिए किया जाता है।

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

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 Formula {
   public static void main(String[] args)throws Exception {
      XSSFWorkbook workbook = new XSSFWorkbook(); 
      XSSFSheet spreadsheet = workbook.createSheet("formula");
      XSSFRow row = spreadsheet.createRow(1);
      XSSFCell cell = row.createCell(1);
      
      cell.setCellValue("A = ");
      cell = row.createCell(2);
      cell.setCellValue(2);
      row = spreadsheet.createRow(2);
      cell = row.createCell(1);
      cell.setCellValue("B = ");
      cell = row.createCell(2);
      cell.setCellValue(4);
      row = spreadsheet.createRow(3);
      cell = row.createCell(1);
      cell.setCellValue("Total = ");
      cell = row.createCell(2);
      
      // Create SUM formula
      cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
      cell.setCellFormula("SUM(C2:C3)");
      cell = row.createCell(3);
      cell.setCellValue("SUM(C2:C3)");
      row = spreadsheet.createRow(4);
      cell = row.createCell(1);
      cell.setCellValue("POWER =");
      cell=row.createCell(2);
      
      // Create POWER formula
      cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
      cell.setCellFormula("POWER(C2,C3)");
      cell = row.createCell(3);
      cell.setCellValue("POWER(C2,C3)");
      row = spreadsheet.createRow(5);
      cell = row.createCell(1);
      cell.setCellValue("MAX = ");
      cell = row.createCell(2);
      
      // Create MAX formula
      cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
      cell.setCellFormula("MAX(C2,C3)");
      cell = row.createCell(3);
      cell.setCellValue("MAX(C2,C3)");
      row = spreadsheet.createRow(6);
      cell = row.createCell(1);
      cell.setCellValue("FACT = ");
      cell = row.createCell(2);
      
      // Create FACT formula
      cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
      cell.setCellFormula("FACT(C3)");
      cell = row.createCell(3);
      cell.setCellValue("FACT(C3)");
      row = spreadsheet.createRow(7);
      cell = row.createCell(1);
      cell.setCellValue("SQRT = ");
      cell = row.createCell(2);
      
      // Create SQRT formula
      cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
      cell.setCellFormula("SQRT(C5)");
      cell = row.createCell(3);
      cell.setCellValue("SQRT(C5)");
      workbook.getCreationHelper().createFormulaEvaluator().evaluateAll();
      FileOutputStream out = new FileOutputStream(new File("formula.xlsx"));
      workbook.write(out);
      out.close();
      System.out.println("fromula.xlsx written successfully");
   }
}

उपरोक्त कोड को इस प्रकार सेव करें Formula.java और फिर इसे कमांड प्रॉम्प्ट से इस प्रकार संकलित और निष्पादित करें।

$javac Formula.java
$java Formula

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

fromula.xlsx written successfully

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