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

📄 hssfworkbook.java

📁 java 报表 to office文档: 本包由java语言开发
💻 JAVA
📖 第 1 页 / 共 3 页
字号:
/* ====================================================================   Copyright 2002-2004   Apache Software Foundation   Licensed under the Apache License, Version 2.0 (the "License");   you may not use this file except in compliance with the License.   You may obtain a copy of the License at       http://www.apache.org/licenses/LICENSE-2.0   Unless required by applicable law or agreed to in writing, software   distributed under the License is distributed on an "AS IS" BASIS,   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.   See the License for the specific language governing permissions and   limitations under the License.==================================================================== *//* * HSSFWorkbook.java * * Created on September 30, 2001, 3:37 PM */package org.apache.poi.hssf.usermodel;import org.apache.poi.ddf.EscherBSERecord;import org.apache.poi.ddf.EscherBitmapBlip;import org.apache.poi.ddf.EscherRecord;import org.apache.poi.hssf.eventmodel.EventRecordFactory;import org.apache.poi.hssf.model.Sheet;import org.apache.poi.hssf.model.Workbook;import org.apache.poi.hssf.record.*;import org.apache.poi.hssf.record.formula.Area3DPtg;import org.apache.poi.hssf.record.formula.MemFuncPtg;import org.apache.poi.hssf.record.formula.UnionPtg;import org.apache.poi.hssf.util.CellReference;import org.apache.poi.poifs.filesystem.*;import org.apache.poi.util.POILogFactory;import org.apache.poi.util.POILogger;import java.io.ByteArrayInputStream;import java.io.IOException;import java.io.InputStream;import java.io.OutputStream;import java.io.PrintWriter;import java.util.ArrayList;import java.util.Iterator;import java.util.List;import java.util.Stack;/** * High level representation of a workbook.  This is the first object most users * will construct whether they are reading or writing a workbook.  It is also the * top level object for creating new sheets/etc. * * @see org.apache.poi.hssf.model.Workbook * @see org.apache.poi.hssf.usermodel.HSSFSheet * @author  Andrew C. Oliver (acoliver at apache dot org) * @author  Glen Stampoultzis (glens at apache.org) * @author  Shawn Laubach (slaubach at apache dot org) * @version 2.0-pre */public class HSSFWorkbook{    private static final int DEBUG = POILogger.DEBUG;    /**     * used for compile-time performance/memory optimization.  This determines the     * initial capacity for the sheet collection.  Its currently set to 3.     * Changing it in this release will decrease performance     * since you're never allowed to have more or less than three sheets!     */    public final static int INITIAL_CAPACITY = 3;    /**     * this is the reference to the low level Workbook object     */    private Workbook workbook;    /**     * this holds the HSSFSheet objects attached to this workbook     */    protected ArrayList sheets;    /**     * this holds the HSSFName objects attached to this workbook     */    private ArrayList names;    /**     * holds whether or not to preserve other nodes in the POIFS.  Used     * for macros and embedded objects.     */    private boolean   preserveNodes;    /**     * if you do preserve the nodes, you'll need to hold the whole POIFS in     * memory.     */    private POIFSFileSystem poifs;    /**     * Used to keep track of the data formatter so that all     * createDataFormatter calls return the same one for a given     * book.  This ensures that updates from one places is visible     * someplace else.     */    private HSSFDataFormat formatter;    /// NOT YET SUPPORTED:    /** Extended windows meta file */    //public static final int PICTURE_TYPE_EMF = 2;    /** Windows Meta File */    //public static final int PICTURE_TYPE_WMF = 3;    /** Mac PICT format */    //public static final int PICTURE_TYPE_PICT = 4;    /** JPEG format */    public static final int PICTURE_TYPE_JPEG = 5;    /** PNG format */    public static final int PICTURE_TYPE_PNG = 6;    /** Device independant bitmap */    public static final int PICTURE_TYPE_DIB = 7;    private static POILogger log = POILogFactory.getLogger(HSSFWorkbook.class);    /**     * Creates new HSSFWorkbook from scratch (start here!)     *     */    public HSSFWorkbook()    {        this(Workbook.createWorkbook());    }    protected HSSFWorkbook( Workbook book )    {        workbook = book;        sheets = new ArrayList( INITIAL_CAPACITY );        names = new ArrayList( INITIAL_CAPACITY );    }    public HSSFWorkbook(POIFSFileSystem fs) throws IOException {      this(fs,true);    }    /**     * given a POI POIFSFileSystem object, read in its Workbook and populate the high and     * low level models.  If you're reading in a workbook...start here.     *     * @param fs the POI filesystem that contains the Workbook stream.     * @param preserveNodes whether to preseve other nodes, such as     *        macros.  This takes more memory, so only say yes if you     *        need to.     * @see org.apache.poi.poifs.filesystem.POIFSFileSystem     * @exception IOException if the stream cannot be read     */    public HSSFWorkbook(POIFSFileSystem fs, boolean preserveNodes)            throws IOException    {        this.preserveNodes = preserveNodes;        if (preserveNodes) {           this.poifs = fs;        }        sheets = new ArrayList(INITIAL_CAPACITY);        names  = new ArrayList(INITIAL_CAPACITY);        InputStream stream = fs.createDocumentInputStream("Workbook");        EventRecordFactory factory = new EventRecordFactory();        List records = RecordFactory.createRecords(stream);        workbook = Workbook.createWorkbook(records);        setPropertiesFromWorkbook(workbook);        int recOffset = workbook.getNumRecords();        int sheetNum = 0;        while (recOffset < records.size())        {            Sheet sheet = Sheet.createSheet(records, sheetNum++, recOffset );            recOffset = sheet.getEofLoc()+1;            sheet.convertLabelRecords(                    workbook);   // convert all LabelRecord records to LabelSSTRecord            HSSFSheet hsheet = new HSSFSheet(workbook, sheet);            sheets.add(hsheet);            // workbook.setSheetName(sheets.size() -1, "Sheet"+sheets.size());        }        for (int i = 0 ; i < workbook.getNumNames() ; ++i){            HSSFName name = new HSSFName(workbook, workbook.getNameRecord(i));            names.add(name);        }    }     public HSSFWorkbook(InputStream s) throws IOException {         this(s,true);     }    /**     * Companion to HSSFWorkbook(POIFSFileSystem), this constructs the POI filesystem around your     * inputstream.     *     * @param s  the POI filesystem that contains the Workbook stream.     * @param preserveNodes whether to preseve other nodes, such as     *        macros.  This takes more memory, so only say yes if you     *        need to.     * @see org.apache.poi.poifs.filesystem.POIFSFileSystem     * @see #HSSFWorkbook(POIFSFileSystem)     * @exception IOException if the stream cannot be read     */    public HSSFWorkbook(InputStream s, boolean preserveNodes)            throws IOException    {        this(new POIFSFileSystem(s), preserveNodes);    }    /**     * used internally to set the workbook properties.     */    private void setPropertiesFromWorkbook(Workbook book)    {        this.workbook = book;        // none currently    }    /**     * sets the order of appearance for a given sheet.     *     * @param sheetname the name of the sheet to reorder     * @param pos the position that we want to insert the sheet into (0 based)     */    public void setSheetOrder(String sheetname, int pos ) {        workbook.setSheetOrder(sheetname, pos);    }    public final static byte ENCODING_COMPRESSED_UNICODE = 0;    public final static byte ENCODING_UTF_16             = 1;    /**     * set the sheet name.     * Will throw IllegalArgumentException if the name is greater than 31 chars     * or contains /\?*[]     * @param sheet number (0 based)     */    public void setSheetName(int sheet, String name)    {        if (workbook.doesContainsSheetName( name, sheet ))            throw new IllegalArgumentException( "The workbook already contains a sheet with this name" );        workbook.setSheetName( sheet, name, ENCODING_COMPRESSED_UNICODE );    }    public void setSheetName( int sheet, String name, short encoding )    {        if (workbook.doesContainsSheetName( name, sheet ))            throw new IllegalArgumentException( "The workbook already contains a sheet with this name" );        if (sheet > (sheets.size() - 1))        {            throw new RuntimeException("Sheet out of bounds");        }        switch ( encoding ) {        case ENCODING_COMPRESSED_UNICODE:        case ENCODING_UTF_16:            break;        default:            // TODO java.io.UnsupportedEncodingException            throw new RuntimeException( "Unsupported encoding" );        }        workbook.setSheetName( sheet, name, encoding );    }    /**     * get the sheet name     * @param sheet Number     * @return Sheet name     */    public String getSheetName(int sheet)    {        if (sheet > (sheets.size() - 1))        {            throw new RuntimeException("Sheet out of bounds");        }        return workbook.getSheetName(sheet);    }    /*     * get the sheet's index     * @param name  sheet name     * @return sheet index or -1 if it was not found.     */    /** Returns the index of the sheet by his name     * @param name the sheet name     * @return index of the sheet (0 based)     */    public int getSheetIndex(String name)    {        int retval = workbook.getSheetIndex(name);        return retval;    }    /**     * create an HSSFSheet for this HSSFWorkbook, adds it to the sheets and returns     * the high level representation.  Use this to create new sheets.     *     * @return HSSFSheet representing the new sheet.     */    public HSSFSheet createSheet()    {//        if (getNumberOfSheets() == 3)//            throw new RuntimeException("You cannot have more than three sheets in HSSF 1.0");        HSSFSheet sheet = new HSSFSheet(workbook);        sheets.add(sheet);        workbook.setSheetName(sheets.size() - 1,                "Sheet" + (sheets.size() - 1));        WindowTwoRecord windowTwo = (WindowTwoRecord) sheet.getSheet().findFirstRecordBySid(WindowTwoRecord.sid);        windowTwo.setSelected(sheets.size() == 1);        windowTwo.setPaged(sheets.size() == 1);        return sheet;    }    /**     * create an HSSFSheet from an existing sheet in the HSSFWorkbook.     *     * @return HSSFSheet representing the cloned sheet.     */    public HSSFSheet cloneSheet(int sheetNum) {      HSSFSheet srcSheet = (HSSFSheet)sheets.get(sheetNum);      String srcName = workbook.getSheetName(sheetNum);      if (srcSheet != null) {        HSSFSheet clonedSheet = srcSheet.cloneSheet(workbook);        WindowTwoRecord windowTwo = (WindowTwoRecord) clonedSheet.getSheet().findFirstRecordBySid(WindowTwoRecord.sid);        windowTwo.setSelected(sheets.size() == 1);        windowTwo.setPaged(sheets.size() == 1);        sheets.add(clonedSheet);        if (srcName.length()<28) {            workbook.setSheetName(sheets.size()-1, srcName+"(2)");        }else {            workbook.setSheetName(sheets.size()-1,srcName.substring(0,28)+"(2)");        }        return clonedSheet;      }      return null;    }    /**     * create an HSSFSheet for this HSSFWorkbook, adds it to the sheets and returns     * the high level representation.  Use this to create new sheets.     *     * @param sheetname     sheetname to set for the sheet.     * @return HSSFSheet representing the new sheet.     */    public HSSFSheet createSheet(String sheetname)

⌨️ 快捷键说明

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