Apache POI - Tabellenkalkulationen

In diesem Kapitel wird erläutert, wie Sie eine Tabelle erstellen und mit Java bearbeiten. Tabellenkalkulation ist eine Seite in einer Excel-Datei. Es enthält Zeilen und Spalten mit bestimmten Namen.

Nach Abschluss dieses Kapitels können Sie eine Tabelle erstellen und Lesevorgänge ausführen.

Erstellen Sie eine Tabelle

Lassen Sie uns zunächst eine Tabelle mit den in den vorherigen Kapiteln beschriebenen Klassen erstellen, auf die verwiesen wird. Wenn Sie dem vorherigen Kapitel folgen, erstellen Sie zuerst eine Arbeitsmappe. Anschließend können Sie ein Blatt erstellen.

Das folgende Codefragment wird zum Erstellen einer Tabelle verwendet.

//Create Blank workbook
XSSFWorkbook workbook = new XSSFWorkbook();

//Create a blank spreadsheet
XSSFSheet spreadsheet = workbook.createSheet("Sheet Name");

Zeilen in der Tabelle

Tabellenkalkulationen haben ein Rasterlayout. Die Zeilen und Spalten sind mit bestimmten Namen gekennzeichnet. Die Spalten sind mit Alphabeten und Zeilen mit Zahlen gekennzeichnet.

Das folgende Codefragment wird zum Erstellen einer Zeile verwendet.

XSSFRow row = spreadsheet.createRow((short)1);

Schreiben Sie in eine Tabelle

Betrachten wir ein Beispiel für Mitarbeiterdaten. Hier werden die Mitarbeiterdaten tabellarisch dargestellt.

Emp Id Emp Name Bezeichnung
Tp01 Gopal Technischer Manager
TP02 Manisha Proof Reader
Tp03 Masthan Technischer Schreiber
Tp04 Satish Technischer Schreiber
Tp05 Krishna Technischer Schreiber

Der folgende Code wird verwendet, um die obigen Daten in eine Tabelle zu schreiben.

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");
   }
}

Speichern Sie den obigen Java-Code als Writesheet.java, und kompilieren Sie es dann und führen Sie es an der Eingabeaufforderung wie folgt aus:

$javac Writesheet.java
$java Writesheet

Es wird kompiliert und ausgeführt, um eine Excel-Datei mit dem Namen zu generieren Writesheet.xlsx in Ihrem aktuellen Verzeichnis und Sie erhalten die folgende Ausgabe in der Eingabeaufforderung.

Writesheet.xlsx written successfully

Das Writesheet.xlsx Datei sieht wie folgt aus.

Lesen Sie aus einer Tabelle

Betrachten wir die oben genannte Excel-Datei mit dem Namen Writesheet.xslxals Eingabe. Beachten Sie den folgenden Code; Es wird zum Lesen der Daten aus einer Tabelle verwendet.

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();
   }
}

Lassen Sie uns den obigen Code beibehalten Readsheet.java Datei, und kompilieren Sie es dann und führen Sie es an der Eingabeaufforderung wie folgt aus:

$javac Readsheet.java
$java Readsheet

Wenn Ihre Systemumgebung mit der POI-Bibliothek konfiguriert ist, wird sie kompiliert und ausgeführt, um die folgende Ausgabe in der Eingabeaufforderung zu generieren.

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