⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 eventexample.java

📁 Office格式转换代码
💻 JAVA
字号:
package org.apache.poi.hssf.usermodel.examples;import org.apache.poi.hssf.eventusermodel.HSSFEventFactory;import org.apache.poi.hssf.eventusermodel.HSSFListener;import org.apache.poi.hssf.eventusermodel.HSSFRequest;import org.apache.poi.hssf.record.*;import org.apache.poi.poifs.filesystem.POIFSFileSystem;import java.io.FileInputStream;import java.io.IOException;import java.io.InputStream;/** * This example shows how to use the event API for reading a file. */public class EventExample        implements HSSFListener{    private SSTRecord sstrec;    /**     * This method listens for incoming records and handles them as required.     * @param record    The record that was found while reading.     */    public void processRecord(Record record)    {        switch (record.getSid())        {            // the BOFRecord can represent either the beginning of a sheet or the workbook            case BOFRecord.sid:                BOFRecord bof = (BOFRecord) record;                if (bof.getType() == bof.TYPE_WORKBOOK)                {                    System.out.println("Encountered workbook");                    // assigned to the class level member                } else if (bof.getType() == bof.TYPE_WORKSHEET)                {                    System.out.println("Encountered sheet reference");                }                break;            case BoundSheetRecord.sid:                BoundSheetRecord bsr = (BoundSheetRecord) record;                System.out.println("New sheet named: " + bsr.getSheetname());                break;            case RowRecord.sid:                RowRecord rowrec = (RowRecord) record;                System.out.println("Row found, first column at "                        + rowrec.getFirstCol() + " last column at " + rowrec.getLastCol());                break;            case NumberRecord.sid:                NumberRecord numrec = (NumberRecord) record;                System.out.println("Cell found with value " + numrec.getValue()                        + " at row " + numrec.getRow() + " and column " + numrec.getColumn());                break;                // SSTRecords store a array of unique strings used in Excel.            case SSTRecord.sid:                sstrec = (SSTRecord) record;                for (int k = 0; k < sstrec.getNumUniqueStrings(); k++)                {                    System.out.println("String table value " + k + " = " + sstrec.getString(k));                }                break;            case LabelSSTRecord.sid:                LabelSSTRecord lrec = (LabelSSTRecord) record;                System.out.println("String cell found with value "                        + sstrec.getString(lrec.getSSTIndex()));                break;        }    }    /**     * Read an excel file and spit out what we find.     *     * @param args      Expect one argument that is the file to read.     * @throws IOException  When there is an error processing the file.     */    public static void main(String[] args) throws IOException    {        // create a new file input stream with the input file specified        // at the command line        FileInputStream fin = new FileInputStream(args[0]);        // create a new org.apache.poi.poifs.filesystem.Filesystem        POIFSFileSystem poifs = new POIFSFileSystem(fin);        // get the Workbook (excel part) stream in a InputStream        InputStream din = poifs.createDocumentInputStream("Workbook");        // construct out HSSFRequest object        HSSFRequest req = new HSSFRequest();        // lazy listen for ALL records with the listener shown above        req.addListenerForAllRecords(new EventExample());        // create our event factory        HSSFEventFactory factory = new HSSFEventFactory();        // process our events based on the document input stream        factory.processEvents(req, din);        // once all the events are processed close our file input stream        fin.close();        // and our document input stream (don't want to leak these!)        din.close();        System.out.println("done.");    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -